vue 怎么拿到router.push传递的数据?

 我来答
帐号已注销
高粉答主

推荐于2019-08-05 · 说的都是干货,快来关注
知道大有可为答主
回答量:221
采纳率:25%
帮助的人:4万
展开全部

vue 怎么拿到router.push传递的数据:

主要有以下几个步骤:

(1) 设置好路由配置

router.map({  '/history/:deviceId/:dataId': {
name: 'history', // give the route a name
component: { ... }
}
})

这里有2个关键点:

a)给该路由命名,也就是上文中的 name: 'history',

b)在路径中要使用在路径中使用冒号开头的数字来接受参数,也就是上文中的 :deviceId, :dataId;

(2)在v-link中传递参数;

<a v-link="{ name: 'history', params: { deviceId: 123, dataId:456 }}">history</a>

这里的123,456都可以改用变量。

比如该template所对应的组件有2个变量定义如下:

data: function() {

return {

deviceId:123,

dataId:456

}

}    

此时上面那个v-link可以改写为:

<a v-link="{ name: 'history', params: { deviceId: deviceId, dataId: dataId }}">history</a>

(3)在router的目标组件上获取入参

比如在router目标组件的ready函数中可以这么使用。

ready: function(){

console.log('deviceid: ' + this.$route.params.deviceId);

console.log('dataId: ' + this.$route.params.dataId);

}

————完————

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式