首先說一下這是本人第一次分享東西第一次寫,寫的很差或者有錯誤的請你們多包涵支出錯誤共同進步加粗文字
第一步 安裝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