欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用vue + koa2 + mockjs模擬數(shù)據(jù)的方法教程

 更新時(shí)間:2017年11月22日 09:53:55   作者:謝彪  
這篇文章主要給大家介紹了關(guān)于利用vue + koa2 + mockjs模擬數(shù)據(jù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

首先說(shuō)一下這是本人第一次分享東西第一次寫(xiě),寫(xiě)的不好或者有錯(cuò)誤的請(qǐng)大家多包涵支出錯(cuò)誤共同進(jìn)步,好了,話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。

關(guān)于mockjs,官網(wǎng)描述的是

      1.前后端分離

      2.不需要修改既有代碼,就可以攔截 Ajax 請(qǐng)求,返回模擬的響應(yīng)數(shù)據(jù)。

      3.數(shù)據(jù)類型豐富

      4.通過(guò)隨機(jī)數(shù)據(jù),模擬各種場(chǎng)景。

等等優(yōu)點(diǎn)。

第一步 安裝vue-cli項(xiàng)目 不多說(shuō)網(wǎng)上一大把

需要的朋友們參考這篇文章:http://www.dbjr.com.cn/article/118987.htm ,介紹的非常詳細(xì)。

第二步 因?yàn)楸镜氐膙ue訪問(wèn)本地的mock

1、配置vue代理

    在config/index.js里面的proxyTable,因?yàn)楸镜豱ode啟動(dòng)的服務(wù)默認(rèn)訪問(wèn)的是3000端口

    所以在target里面配置http://localhost:3000/

 proxyTable: {
 '/api': {
 target: 'http://localhost:3000/',
 changeOrigin: true,
 pathRewrite: {
  '^/api': '/'
 }
 }

2、在vue項(xiàng)目的mianjs中

  import axios from 'axios'
  axios.defaults.baseURL = '/api'

第三步 搭建nodejs的koa2項(xiàng)目

全局安裝koa,不是koa2注意

1、npm install -g koa-generator

    創(chuàng)建文件夾下面HelloKoa2是你的項(xiàng)目名字

2、koa2 HelloKoa2

    進(jìn)入該文件夾然后執(zhí)行安裝依賴

3、cd HelloKoa2然后npm install

上面完成了nodejs的初始化接著操作

4、繼續(xù)安裝依賴文件

 npm install mockjs --save -dev //mock文件
 npm install koa2-cors --save -dev //node端配置cors支持跨域用

5、配置app.js文件 注意下面注釋的新增部分就是在本來(lái)app.js文件上面新增的東西

 

 const Koa = require('koa')
 const app = new Koa()
 const views = require('koa-views')
 const json = require('koa-json')
 const onerror = require('koa-onerror')
 const bodyparser = require('koa-bodyparser')
 const logger = require('koa-logger')
 const cors = require('koa2-cors') // 新增部分處理跨域

 //這里提一點(diǎn)題外話 假如routes文件新增一個(gè)路徑就的在下面增加路勁
 //假設(shè)routes新增一個(gè)user.js
 //新增一個(gè)user需要修改兩個(gè)地方這里是一個(gè) 下面還有一個(gè)地方
 //這里需要 const user = require('./routes/user')
 const index = require('./routes/index')
 const users = require('./routes/users')

 // error handler
 onerror(app)

 // middlewares
 app.use(bodyparser({
  enableTypes:['json', 'form', 'text']
 }))
 app.use(cors()) // 新增部分處理跨域
 app.use(json())
 app.use(logger())
 app.use(require('koa-static')(__dirname + '/public'))

 app.use(views(__dirname + '/views', {
  extension: 'pug'
 }))

 // logger
 app.use(async (ctx, next) => {
  const start = new Date()
  await next()
  const ms = new Date() - start
  console.log(`${ctx.method} ${ctx.url} - ${ms}ms`)
 })

 //這里提一點(diǎn)題外話 假如routes文件新增一個(gè)路徑就的在下面增加路勁
 //假設(shè)routes新增一個(gè)user.js
 //這里需要 app.use(user.routes(), user.allowedMethods())
 app.use(index.routes(), index.allowedMethods())
 app.use(users.routes(), users.allowedMethods())

 // error-handling
 app.on('error', (err, ctx) => {
  console.error('server error', err, ctx)
 });

 module.exports = app

6、正式使用mock 我這里直接在routes/index.js里面使用

    routes/index.js文件如下

  const router = require('koa-router')()
  var Mock = require('mockjs') //引入mockjs
  const Random = Mock.Random;  //引入mockjs生成隨機(jī)屬性的函數(shù) random具體可以生成
          //哪些東西詳見(jiàn)http://mockjs.com/examples.html
  router.prefix('/index')

  router.get('/string', async (ctx, next) => {
   //116到125 是mock的第一種使用方法,這種方法隨機(jī)生成1到10個(gè)數(shù)組但是每個(gè)數(shù)組的author、title等都一樣
   // ctx.body = await Mock.mock({
   // // 屬性 list 的值是一個(gè)數(shù)組,其中含有 1 到 10 個(gè)元素
   // 'arr|1-10': [{
   //  // 屬性 id 是一個(gè)自增數(shù),起始值為 1,每次增 1
   //  'id|+1': 1,
   //  'author|+1': Random.cname(),
   //  'img': Random.image('100x100'),
   //  'title':Random.csentence(5, 9) 
   // }]
   // }) 
   //127到141是mock的第二種方法主要使用Random函數(shù)來(lái)生成 這里生成的title、author等每個(gè)都不一樣
   const produceNewsData = function() {
    let articles = [];
    for (let i = 0; i < 50; i++) {
     let newArticleObject = {
      title: Random.csentence(5, 30), // Random.csentence( min, max )
      author: Random.cname(), // Random.cname() 隨機(jī)生成一個(gè)常見(jiàn)的中文姓名
     }
     articles.push(newArticleObject)
    }

    return {
     articles: articles
    }
   }
   ctx.body = await produceNewsData()
  })

這里提一點(diǎn) http://mockjs.com/examples.html 官網(wǎng) 看清楚每種數(shù)據(jù)的用法

7、啟動(dòng)node

 npm run dev

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • vue3父子組件相互調(diào)用方法詳解

    vue3父子組件相互調(diào)用方法詳解

    在vue3項(xiàng)目開(kāi)發(fā)中,我們常常會(huì)遇到父子組件相互調(diào)用的場(chǎng)景,下面主要以setup語(yǔ)法糖格式詳細(xì)聊聊父子組件那些事兒,并通過(guò)代碼示例介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-05-05
  • Vue模擬響應(yīng)式原理底層代碼實(shí)現(xiàn)的示例

    Vue模擬響應(yīng)式原理底層代碼實(shí)現(xiàn)的示例

    最近去面試的人都會(huì)有這個(gè)體會(huì),去年面試官只問(wèn)我怎么用vue,今年開(kāi)始問(wèn)我vue響應(yīng)式原理,本文就詳細(xì)的介紹一下
    2021-08-08
  • Vue封裝DateRangePicker組件流程詳細(xì)介紹

    Vue封裝DateRangePicker組件流程詳細(xì)介紹

    在后端管理項(xiàng)目中使用vue來(lái)進(jìn)行前端項(xiàng)目的開(kāi)發(fā),但我們都知道Vue實(shí)際上無(wú)法監(jiān)聽(tīng)由第三方插件所引起的數(shù)據(jù)變化。也無(wú)法獲得JQuery這樣的js框架對(duì)元素值的修改的。而日期控件daterangepicker又基于JQuery來(lái)實(shí)現(xiàn)的
    2022-11-11
  • Vue實(shí)現(xiàn)批量注冊(cè)全局組件的示例代碼

    Vue實(shí)現(xiàn)批量注冊(cè)全局組件的示例代碼

    在項(xiàng)目開(kāi)發(fā)中,我們經(jīng)常會(huì)封裝一些全局組件,然后在入口文件中統(tǒng)一導(dǎo)入,所以本文主要為大家詳細(xì)介紹了Vue如何批量注冊(cè)全局組件,感興趣的小伙伴可以了解下
    2024-01-01
  • VueQuillEditor富文本上傳圖片(非base64)

    VueQuillEditor富文本上傳圖片(非base64)

    這篇文章主要介紹了VueQuillEditor富文本上傳圖片(非base64),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • vue實(shí)現(xiàn)打印功能的示例代碼

    vue實(shí)現(xiàn)打印功能的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何通過(guò)vue實(shí)現(xiàn)打印功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • vue3生命周期原理與生命周期函數(shù)簡(jiǎn)單應(yīng)用實(shí)例分析

    vue3生命周期原理與生命周期函數(shù)簡(jiǎn)單應(yīng)用實(shí)例分析

    這篇文章主要介紹了vue3生命周期原理與生命周期函數(shù),結(jié)合簡(jiǎn)單實(shí)例形式分析了vue3的生命周期基本原理、以及各個(gè)階段的生命周期鉤子函數(shù)功能、使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2023-04-04
  • vue實(shí)現(xiàn)給某個(gè)數(shù)據(jù)字段添加顏色

    vue實(shí)現(xiàn)給某個(gè)數(shù)據(jù)字段添加顏色

    這篇文章主要介紹了vue實(shí)現(xiàn)給某個(gè)數(shù)據(jù)字段添加顏色方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 關(guān)于Vue組件間的常用傳參方式

    關(guān)于Vue組件間的常用傳參方式

    這篇文章主要介紹了關(guān)于Vue組件間的常用傳參方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue.js第四天學(xué)習(xí)筆記

    Vue.js第四天學(xué)習(xí)筆記

    這篇文章主要為大家詳細(xì)介紹了Vue.js第四天的學(xué)習(xí)筆記,json數(shù)組數(shù)據(jù)以csv格式導(dǎo)出,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評(píng)論