时间:2021-05-26
一、路由
首先需要配置路由,就是点击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模拟数据,实现路由进入商品详情页面的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
vue中,我们所要实现的一个场景就是:1.搜索页面==>到搜索结果页时,搜索结果页面要重新获取数据,2.搜索结果页面==>点击进入详情页==>从详情页返回列表页
需求:商品列表页面浏览,进入商品详情,点击返回仍然是之前浏览的位置实现:使用vue的keep-alive的include属性给组件做动态缓存,从详情页返回不变,
本文实例讲述了微信小程序实现的动态设置导航栏标题功能。分享给大家供大家参考,具体如下:场景当从一个分类列表页面进入到一个详情页面的时候,由于这个详情页面是公用的
1、首先找到中意的商品,点击进入详情页面,在手机页面下边点击收藏,收藏此物版品。2、返回权至淘宝页面首页,点击我的淘宝,点击收藏夹,进入到收藏物品详情页面。3、
客户通过关键词搜索进入宝贝详情页,进入后浏览10秒后关闭页面。这说明说明,说明详情页对客户不够吸引无法激起购买欲。主动进入店铺或商品的流量,如果因为详情页而