vue 中query和pramas中的那点事

技术vue 中query和pramas中的那点事 vue 中query和pramas中的那点事//$router : 是路由操作对象,只写对象
//$route : 路由信息对象,只读对象
//操作 路

关于vue中查询和pramas的事情

//$router :是路由操作对象,只写对象。

//$route :路由信息对象,只读对象

//操作路线跳转

这个。$ router . push({ 0

姓名: '你好',

参数:{

名称: '单词',

年龄:'11 '

}

})

//读取路由参数接收

这个,名字=这个。$ route . params . name;

这个年龄=这个。$ route . params . age;

查询参数要按路径引入(也可以按名称引入),params参数要按名称引入。

//查询参数,使用名称跳转。

这个。$ router . push({ 0

名称: '秒',

查询: {

queryId:'20180822 ',

queryName:“查询”

}

})

//查询参数,使用路径跳转

这个。$ router . push({ 0

路径: '秒',

查询: {

queryId:'20180822 ',

queryName:“查询”

}

})

//查询参数发送和接收

this.queryName=this。$ route . query . query name;

this.queryId=this。$ route . query . queryid;

2params传递参数

注意:参数只能通过名字来介绍。

//params参数使用名称。

这个。$ router . push({ 0

名称: '秒',

参数: {

id:'20180822 ',

名称:“查询”

}

})

//参数接收参数

this.id=this。$ route . params . id;

这个,名字=这个。$ route . params . name;

//路由

{

path : '/second/: id/: name ',

名称: '秒',

component :()=import(@/view/second)

}

应该指出的是:

Params是路由的一部分,参数名称必须添加在路由之后。查询是在url后拼接的参数。没有也没关系。

一旦在路线中设置了参数,参数就是路线的一部分。如果此路由有params参数,但在跳转过程中没有传递此参数,将导致跳转失败或页面没有内容。

如果路由后面没有/:ID/3360Name地址栏,则没有参数,但如果刷新,会发现页面获取参数失败。

因此,我们不可能阻止用户刷新,所以我们必须在路由后添加/:id/:name。

//params参数使用路径。

这个。$ router . push({ 0

路径: '秒',

参数: {

id:'20180822 ',

名称:“查询”

}

})

//参数接收参数

this.id=this。$ route . params . id;

这个,名字=这个。$ route . params . name;

摘要

参数可以通过参数和查询传递。

使用params参数时,只能使用名称引入路由,即push只能包含name:'xxxx ',不能包含path:'/xxx'/XXX ',因为params只能使用名称引入路由。如果在这里写path,接收参数页将是未定义的!

使用查询参数使用路径引入路线。

Params是路由的一部分,参数名称必须添加在路由之后。查询是在url后拼接的参数。没有也没关系。

这两者有些不同。说白了,查询相当于获取请求。当页面跳转时,可以在地址栏看到请求参数,而params相当于post request,参数不会显示在地址栏。

解决问题:vue通过名称和参数调整页面参数,刷新参数丢失。

导出默认的新路由器({ 0

路线: [

{

路径: '/',

redirect: '/main ',

},{

path: '/main ',

名称: '主',

component :()=import(' @/view/Main '),

儿童: [

{

//path: '/testPage ',//此方法不配置参数名,刷新页面时参数会丢失。

路径: '/test page/: aaa/3360 bbb ',//这样在按名称和参数刷新页面时,参数AAA和BBB不会丢失。

名称: '测试页',

component :()=import(@/view/test page/test page)

},

]

},

]

})

methods: {

//路由调整参数传输测试

gorouttest(){ 0

//这个。$ router . push('/test page ');

这个。$ router . push({ name : ' TestPage ',params: { aaa: ' 111 ',BBB : ' 222 ' });

}

},

如果params用作对象,刷新页面将消失。

解决方案JSON.stringify()方法用于将JavaScript值转换为JSON字符串。然后在组件内部使用JSON,parse()再次转换为对象。或者选择vuex模式来传输组件内容中的值,并通过计算属性获得它们。

路由组件传参

在组件中使用$route会使其与其对应的route高度耦合,使得组件只能在一些特定的URL上使用,限制了其灵活性。

用道具分离组件和路由:而不是用$route耦合

常量用户={ 0

template :“DiV USer { { $ route . params . id } }/DiV”

}

const router=new VueRouter({ 0

routes :[{ path : '/User/: id ',component: User }]

})

常量用户={ 0

prop :[' id '],

template :“DiV USer { { id } }/DiV”

}

const router=new VueRouter({ 0

路线: [

{ path: '/user/:id ',component: User,props: true },

//对于包含命名视图的路线,必须分别为每个命名视图添加道具选项:

{

path: '/user/:id ',

组件: {默认值:用户,侧栏:侧栏},

props: { default: true,sidebar: false }

}

]

})

通过道具解耦如果道具设置为真,route.params将被设置为组件属性。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/81991.html

(0)

相关推荐

  • 如何理解UML时序图

    技术如何理解UML时序图如何理解UML时序图,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。UML时序图简介时序图(SequenceDiagram)是强调

    攻略 2021年11月23日
  • 太岁是什么意思,民间说的“太岁”是什么意思

    技术太岁是什么意思,民间说的“太岁”是什么意思太岁又称岁阴。是假想的天体。尔后,演变成一种神祇信仰。并且,汉族民间传说太岁运行到哪,相应的方位下会出现一块肉状物,是太岁星的化身,在此处动土,会惊动太岁,所以汉族俗语有“不

    生活 2021年10月29日
  • 如何使用matplotlib画图直接写入excel

    技术如何使用matplotlib画图直接写入excel小编给大家分享一下如何使用matplotlib画图直接写入excel,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下

    攻略 2021年12月8日
  • oracle如何加快回滚速度

    技术oracle如何加快回滚速度这篇文章将为大家详细讲解有关oracle如何加快回滚速度,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。记得一次大批量删除数据时,由于回滚段满,导致del

    攻略 2021年11月11日
  • RK3328芯片解决方案相城派R1 Plus开发板如何使用SSH远程登录?

    技术RK3328芯片方案香橙派R1 Plus开发板是如何使用SSH远程登录RK3328芯片方案香橙派R1 Plus开发板是如何使用SSH远程登录,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解

    攻略 2021年12月23日
  • 美的电饭煲怎么用,美的全智能电饭煲预约怎么用

    技术美的电饭煲怎么用,美的全智能电饭煲预约怎么用一美的电饭煲怎么用、工具/原料 电饭煲一个 二、方法/步骤
    1、在洗干净的锅里放上适量的清水和干净的白米。 2、打开电源开关,让电饭煲通电。 3、按下功能开关,选择自己需

    生活 2021年10月27日