路由跳转传参知识点和相关面试题

    //三种路由传递参数
        //字符串方法
        this.$router.push('/search/'+this.keyword+"?k="+this.keyword.toUpperCase())
        //模板字符串
        this.$router.push(`/search/${this.keyword}?k=${this.keyword.toUpperCase()}`)
        //对象方法(最常用)
        this.$router.push({name:'search',params:{keyword:this.keyword},query:{k:this.keyword.toUpperCase()}})

相关面试题
1.路由传递参数(对象写法)path是否可以结合params参数一起使用?
---- 答:不能,路由传参的时候对象的写法可以使name,path形式,但是path不能和params参数一起使用
2.如何指定params参数可传或不可传?
----如果配置路由的时候params参数已经占位了,那么不传递params参数就会导致url有问题,在配置路由的时候,在占位的后面加上一个问号表示params可传或不传
3.当params可传或不传时,如果传递的是空串如何解决?
----使用undefind
params:{keyword:this.keyword||undefined}
4.路由组件能不能传递props数据?

----能
方法:
布尔值写法:props:true
对象写法:额外的给路由组件传递一些props : props:{a:1,b:2}
函数写法:可以params参数,query参数,通过props传递给路由组件
props:(KaTeX parse error: Expected '}', got 'EOF' at end of input: …eturn {keyword:route.params.keyword,k:$route.query.k}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值