在项目开发中,先后台分离,作了假数据,项目使用vue2.0重构,后台也推到重来了,为了避免耽误开发进程,我作了虚拟的数据请求,使用vue-cli脚手架搭建的项目文件中dev-server搭建虚拟api请求,访问本身mock的假数据虚拟请求后台的模式,具体作法以下vue
在build/dev-server.js文件中ios
在var app = express()这个实例的下面添加以下代码vue-cli
// 本地json-server服务器搭建代码 // 引入数据库文件 var appData = require('../mock.json') // 引入数据库 var getBoardList = appData.getBoardList var apiRoutes = express.Router() // 使用api的方法来建立链接时候的请求 apiRoutes.post('/getBoardList', function (req, res) { res.json({ errno: 0 , data: getBoardList }); }) // 调用api app.use('/api', apiRoutes)
其中 数据库
appData 依赖的mock.json文件是本身mock的假数据的文件,根据先后台需求本身mock或者使用mock.js制做假数据
数据大概格式以下
{ "getBoardList": { "logn":"0", "msg": { "name": "精灵", "sign": "一只可爱的小精灵", "src": "", "phoneNub": "15120171717", "six": "未知", "job": "私人金融专家", "add": "北京市 朝阳区 将台" } } }
getBoardList是一个接口,
var getBoardList = appData.getBoardList 就是在appData定义了这一个接口数据。
var apiRoutes = express.Router() 是建立了一个api的路由,apiRoutes.post是建立一个post接口,这个post接口有一个req和一个res参数,分别执行请求和返回,当返回的时候会给咱们一个
json,这个json包括一个状态码errno和返回的数据data(data指向了接口数据getBoardList)。
而后当咱们调用api的时候app.use('/api', apiRoutes),就能正常使用这个服务了
这里我使用了vue2.0推荐的axios请求数据,代码以下
this.$http.post('/api/getBoardList') .then(function (response) { console.log(response.data.data); alert('成功了'); }) .catch(function (code) { alert('失败了'); console.log(code); });
打开浏览器的控制台的network,你会发现已经产生了网络请求
同时,数据也愉快的返回回来了:express
若是想添加接口数据,继续在dev-server.js中添加就能够了,post,get等等均可以。npm
注意,每次更改dev-server.js后须要从新npm run dev启动项目json