vue-cli项目如何使用vue-resource获取本地的json数据(模拟服务端返回数据)


Posted in Javascript onAugust 04, 2017

最近使用vue-cli做了一个小小的项目,在项目中需要使用vue-resource来与后台进行数据交互,所以我使用了本地json数据来模仿后台获取数据的流程。

至于vue-resource的安装和json的准备我就不赘述了、、、

下面是操作方法:

1、首先介绍一下项目的结构:将本地的json文件放在最外层和index.html在一起,姑且叫做data.json。

我的json数据文件大概如此:

{
 "seller": {
   "name": "粥品香坊(回龙观)",
   "description": "蜂鸟专送",
   "bulletin": "会指定餐饮服务商。",
   "avatar": "http://static.galileo.xiaojukeji.com/static/tms/seller_avatar_256px.jpg",
 },
 "goods": [
   {
    "name": "热销榜",
    "type": -1
   },
   {
    "name": "热销榜",
    "type": -1
   }
 ],
 "ratings": [
  {
   "username": "3******c",
   "avatar": "http://static.galileo.xiaojukeji.com/static/tms/default_header.png",
   "recommend": [
    "南瓜粥",
    "皮蛋瘦肉粥"
   ]
  },
  {
   "username": "2******3",
   "avatar": "http://static.galileo.xiaojukeji.com/static/tms/default_header.png",
   "recommend": [
    "扁豆焖面"
   ]
  }
 ]
}

2、接着在build的dev-server.js中进行加入代码:

//模拟服务器返回数据--开始
var appData = require('../data.json');
var seller = appData.seller;
var goods = appData.goods;
var ratings = appData.ratings;

var apiRoutes = express.Router();

apiRoutes.get('/seller', function (req, res) {
 res.json({
  errno: 0,
  data: seller
 });
});

apiRoutes.get('/goods', function (req, res) {
 res.json({
  errno: 0,
  data: goods
 });
});

apiRoutes.get('/ratings', function (req, res) {
 res.json({
  errno: 0,
  data: ratings
 });
});

app.use('/api', apiRoutes);
//模拟服务器返回数据--结束

特别注意:修改好后重新进行cnpm run dev(注意当dev-server.js和db.json改变后都需要进行该步骤)。

解释下以上代码:

1》首先请求根目录下的data.json文件,获取到文件内容并将其赋值给appData变量,然后获取其中的各个字段数据,分别定义变量seller、goods,ratings来赋值。

2》之后,通过express提供的Router对象及其一些方法(这里用的get方法)来设置接口(请求路径)以及请求成功后的回调函数来处理要返回给请求端的数据。(errno这个类似以js请求中的code值)

3》最后,我们要“使用”这个Router对象,为了统一管理api接口,我们在要请求的路由前边都加上‘api/'来表明这个路径是专门用来提供api数据的。在这个“接口”中,当我们访问“http://localhost:8080/api/sites”路径的时候,就会返回db.json里的sites对象给我们。

3、使用resouce获取这些数据,并使用

export default{
 data () {
  return {
   seller: {}
  };
 },
 created () {
  this.$http.get('/api/seller').then((response) => {
   // console.log(response);
   response = response.body;
   const ERR_OK = 0;
   if (response.errno === ERR_OK) {
    let data = response.data;
    console.log(data);
   }
  });
 },
 components: {
  'v-header': header
 }
};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
通过身份证号得到出生日期和性别的js代码
Nov 23 Javascript
Jquery EasyUI的添加,修改,删除,查询等基本操作介绍
Oct 11 Javascript
json定义及jquery操作json的方法
Sep 29 Javascript
微信小程序 获取设备信息 API实例详解
Oct 02 Javascript
详解angularjs的数组传参方式的简单实现
Jul 28 Javascript
深入理解vue中slot与slot-scope的具体使用
Jan 26 Javascript
vue :src 文件路径错误问题的解决方法
May 15 Javascript
vue使用中的内存泄漏【推荐】
Jul 10 Javascript
浅析Vue.js 中的条件渲染指令
Nov 19 Javascript
小程序自定义单页面、全局导航栏的实现代码
Mar 15 Javascript
Javascript三种字符串连接方式及性能比较
May 28 Javascript
node.js基础知识汇总
Aug 25 Javascript
使用jQuery实现鼠标点击左右按钮滑动切换
Aug 04 #jQuery
vue修改vue项目运行端口号的方法
Aug 04 #Javascript
详解Angular2表单-模板驱动的表单(Template-Driven Forms)
Aug 04 #Javascript
微信小程序 本地图片按照屏幕尺寸处理
Aug 04 #Javascript
Javascript实现跨域后台设置拦截的方法详解
Aug 04 #Javascript
微信小程序 五星评分的实现实例
Aug 04 #Javascript
JavaScript中in和hasOwnProperty区别详解
Aug 04 #Javascript
You might like
兼容firefox,chrome的网页灰度效果
2011/08/08 PHP
用php守护另一个php进程的例子
2015/02/13 PHP
PHP用mb_string函数库处理与windows相关中文字符及Win环境下开启PHP Mb_String方法
2015/11/11 PHP
js 第二代身份证号码的验证机制代码
2011/05/12 Javascript
简单实用jquery版三级联动select示例
2013/07/04 Javascript
Jquery对select的增、删、改、查操作
2015/02/06 Javascript
JavaScript将XML转成JSON的方法
2015/03/12 Javascript
Bootstrap基本组件学习笔记之input输入框组(9)
2016/12/07 Javascript
提高Web性能的前端优化技巧总结
2017/02/27 Javascript
详解Angular操作cookies方法
2018/06/01 Javascript
解决layui中table异步数据请求不支持自定义返回数据格式的问题
2018/08/19 Javascript
create-react-app安装出错问题解决方法
2018/09/04 Javascript
layui 弹出层回调获取弹出层数据的例子
2019/09/02 Javascript
解决Vue调用springboot接口403跨域问题
2019/09/02 Javascript
ionic+html5+API实现双击返回键退出应用
2019/09/17 Javascript
整理 node-sass 安装失败的原因及解决办法(小结)
2020/02/19 Javascript
[40:31]Secret vs Alliacne 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
[01:20]PWL开团时刻DAY9——听说潮汐没用?
2020/11/10 DOTA
删除目录下相同文件的python代码(逐级优化)
2012/05/25 Python
python从ftp下载数据保存实例
2013/11/20 Python
Python实现k-means算法
2018/02/23 Python
Python中判断输入是否为数字的实现代码
2018/05/26 Python
pytorch + visdom CNN处理自建图片数据集的方法
2018/06/04 Python
Python爬虫实现(伪)球迷速成
2018/06/10 Python
在Django中URL正则表达式匹配的方法
2018/12/20 Python
python如何以表格形式打印输出的方法示例
2019/06/21 Python
python2和python3实现在图片上加汉字的方法
2019/08/22 Python
10行Python代码计算汽车数量的实现方法
2019/10/23 Python
Python脚本操作Excel实现批量替换功能
2019/11/20 Python
详解Django关于StreamingHttpResponse与FileResponse文件下载的最优方法
2021/01/07 Python
罗马尼亚购物网站:Vivantis.ro
2019/07/20 全球购物
离婚协议书的书写要求
2014/09/17 职场文书
安全隐患整改报告
2014/11/06 职场文书
Python图片处理之图片裁剪教程
2021/05/27 Python
使用Oracle跟踪文件的问题详解
2021/06/28 Oracle
Windows server 2012 NTP时间同步的实现
2022/06/25 Servers