Vue模拟数据,实现路由进入商品详情页面的示例
2018-08-31 15:50
856 查看
一、路由
首先需要配置路由,就是点击good组件进入goodDetail组件
配置路由如下
{ path: '/goodDetail', component:goodDetail }
同时在good组件中写入如下点击事件,路由中加入查询参数,也就是商品的id
//点击路由到商品详细信息页 selectGood(){ router.push({ path: 'goodDetail', query:{goodId:this.goodDetail.id}}) }
二、在goodDetail组件中接收路由参数
goodDetail中的代码如下
export default{ data(){ return { id: this.$route.query.goodId, loading: false, selectedGood: [] } }, created(){ this.fetchData(); }, methods:{ fetchData(){ this.loading = true; //拿到查询字段,商品的id后进行http请求 var id = this.id; this.$http.get('/api/goods/' + id) .then(response => { this.selectedGood = response.data.data; }, error => { console.log(error); }) this.loading = false; } } }
可以看到我这里接收到路由参数的中的商品id后,发送了一个http请求,这时就需要本地mock数据
三、本地模拟数据
首先需要有一个data.json用来存放模拟的数据,然后配置build目录下的dev-server.js如下
//获取mock数据 var appData = require('../data.json'); var goods = appData.goods; var apiRoutes = express.Router(); apiRoutes.get('/goods', function (req, res) { res.json({ errno: 0, data: goods }); }) //拿到指定id的商品信息 apiRoutes.get('/goods/:id', function(req, res) { var id = req.params.id; function selectedGood(id){ for(var i = 0; i < goods.length; i++) { if(goods[i].id == id){ return goods[i]; } } } var good = selectedGood(id); res.json({ errno: 0, // data: goods[req.params.id] data: good }); }) app.use('/api', apiRoutes);
以上这篇Vue模拟数据,实现路由进入商品详情页面的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- Vue模拟数据,实现路由进入商品详情页面
- andriod———1.实现原生登录注册。 2.首页完成商品列表展示点击相对应的商品ID进入商品详情 3.商品详情页面展示数据,点击加入购物车进入购物车页面 4.购物车页面完成购物车编辑,删除,功能
- vue-cli实现多页面多路由的示例代码
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- cc_美团 商品详情页面分享页面实现
- Android中仿淘宝商品详情ViewPager页面数据手动滑动
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- Vue-Router实现页面正在加载特效方法示例
- 学习淘淘商城第六十四课(实现商品详情页面展示)
- Vue数据驱动模拟实现3
- 点击图片之后进入商品详情页面,但是无法加载信息
- 使用Bootstrap + Vue.js实现添加删除数据示例
- vue+vue-router+vuex,利用vue-router2.2.0新增特性addRoutes实现路由动态加载,菜单动态加载,运用于后台管理系统,路由数据取自数据库
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)
- Vue数据驱动模拟实现5
- [导入]AjaxPanel自定义控件实现页面无刷新数据交互(做了个示例程序, 效果确实比较Cool, 用法非常简单! )(示例代码下载)