vue+koa2+mockjs模擬數據

首先說一下這是本人第一次分享東西第一次寫,寫的很差或者有錯誤的請你們多包涵支出錯誤共同進步加粗文字
第一步 安裝vue-cli項目 很少說網上一大把
第二步 由於本地的vue訪問本地的mockhtml

一、配置vue代理
    在config/index.js裏面的proxyTable,由於本地node啓動的服務默認訪問的是3000端口
    因此在target裏面配置http://localhost:3000/
    proxyTable: {
    '/api': {
    target: 'http://localhost:3000/',
    changeOrigin: true,
    pathRewrite: {
      '^/api': '/'
    }
  }
 二、在vue項目的mianjs中
     import axios from 'axios'
     axios.defaults.baseURL = '/api'

第三步 搭建nodejs的koa2項目vue

全局安裝koa,不是koa2注意
一、npm install -g koa-generator
    建立文件夾下面HelloKoa2是你的項目名字
二、koa2 HelloKoa2
    進入該文件夾而後執行安裝依賴
三、cd HelloKoa2而後npm install
上面完成了nodejs的初始化接着操做
四、繼續安裝依賴文件
    npm install mockjs --save -dev //mock文件
    npm install koa2-cors --save -dev //node端配置cors支持跨域用
五、配置app.js文件 注意下面註釋的新增部分就是在原本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') // 新增部分處理跨域

    //這裏提一點題外話 假如routes文件新增一個路徑就的在下面增長路勁
    //假設routes新增一個user.js
    //新增一個user須要修改兩個地方這裏是一個 下面還有一個地方
    //這裏須要 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`)
    })

    //這裏提一點題外話 假如routes文件新增一個路徑就的在下面增長路勁
    //假設routes新增一個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
六、正式使用mock 我這裏直接在routes/index.js裏面使用

    routes/index.js文件以下

        const router = require('koa-router')()
        var Mock = require('mockjs')    //引入mockjs
        const Random = Mock.Random;        //引入mockjs生成隨機屬性的函數 random具體能夠生成
                                        //哪些東西詳見http://mockjs.com/examples.html
        router.prefix('/index')

        router.get('/string', async (ctx, next) => {
            //116到125 是mock的第一種使用方法,這種方法隨機生成1到10個數組可是每一個數組的author、title等都同樣
          // ctx.body = await Mock.mock({
          //   // 屬性 list 的值是一個數組,其中含有 1 到 10 個元素
          //   'arr|1-10': [{
          //     // 屬性 id 是一個自增數,起始值爲 1,每次增 1
          //     'id|+1': 1,
          //     'author|+1': Random.cname(),
          //     'img': Random.image('100x100'),
          //     'title':Random.csentence(5, 9) 
          //   }]
          // })   
          //127到141是mock的第二種方法主要使用Random函數來生成 這裏生成的title、author等每一個都不同
          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() 隨機生成一個常見的中文姓名
                    }
                    articles.push(newArticleObject)
                }

                return {
                    articles: articles
                }
            }
            ctx.body = await  produceNewsData()
        })
        這裏提一點 http://mockjs.com/examples.html 官網 看清楚每種數據的用法
七、啓動node
    npm run dev
相關文章
相關標籤/搜索