千家信息网

Vue-Router如何用

发表于:2025-01-24 作者:千家信息网编辑
千家信息网最后更新 2025年01月24日,这篇文章主要介绍"Vue-Router如何用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Vue-Router如何用"文章能帮助大家解决问题。使用 Vue.j
千家信息网最后更新 2025年01月24日Vue-Router如何用

这篇文章主要介绍"Vue-Router如何用"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Vue-Router如何用"文章能帮助大家解决问题。

使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生。

路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容。Home按钮 => home 内容, about按钮 => about 内容,也可以说是一种映射. 所以在页面上有两个部分,一个是点击部分,一个是点击之后,显示内容的部分。

点击之后,怎么做到正确的对应,比如,我点击home 按钮,页面中怎么就正好能显示home的内容。这就要在js 文件中配置路由。

Vue-Router的最简单使用

1.先注册路由

2.将路由注册到VM组件中

3.定义组件

4.页面定义跳转路径

                                      

使用Router-Link替代a标签

这么做主要是为了去掉a标签中的为了匹配hash地址的"#",如下

                                  
登录 注册

同时,我们还可以利用tag标签来渲染router-link元素,router-link默认渲染为a链接元素,使用tag标签可以渲染其他元素,上述代码中渲染为span元素了。无论渲染成什么元素,都依然与a连接一样拥有跳转的点击事件

重定向技术以及默认路径

默认路径

我们可以使用默认路径的方式指定根路径,只需要在上述路由定义的方式中加入默认路径即可

var routerObj = new VueRouter({      routes:[      //此处的component只能使用组件对象,而不能使用注册的模板的名称        {path:"/",component:login},        {path:"/login",component:login},        {path:"/register",component:register}      ]    })

重定向方式指定默认路径

同样的使用一行代码即可直接重定向到login路径下,相比上述的默认路径,此方式在url的展示上更为明显

var routerObj = new VueRouter({      routes:[      //此处的component只能使用组件对象,而不能使用注册的模板的名称        {path:"/",redirect:"/login"},        {path:"/login",component:login},        {path:"/register",component:register}      ]    })

路由选中之后高亮设置

使用默认类设置为高亮

Vue为router-link内置了一个连接点击之后高亮的类router-link-active,即可以在自己的style中设置

使用自定义类名

当我们想使用第三方定义的选中样式,或者是自己想定义更为简洁的样式,可以使用linkActiveClass来定义,即在路由初始化时指定类名,在指定样式时再自定义样式

var routerObj = new VueRouter({      routes:[      //此处的component只能使用组件对象,而不能使用注册的模板的名称        {path:"/",redirect:"/login"},        {path:"/login",component:login},        {path:"/register",component:register}      ],      linkActiveClass:'myactive'    })

指定样式

路由传参

使用query方式传递参数

首先我们再设置路由链接是指定参数

登录

且可以指定并获取多个参数,主要是再定义的组件对象内部使用created方法来获得

var login={      template:'

登录组件---{{$route.query.id}}--{{$route.query.name}}

', created(){ console.log(this.$route.query.id) } }

使用params方式传递参数

首先我们在路由定义的时候采用:定义params参数

var routerObj = new VueRouter({      routes:[      //此处的component只能使用组件对象,而不能使用注册的模板的名称        {path:"/login/:id/:name",component:login},        {path:"/register",component:register}      ],    })

在实际使用过程中如何传递

   登录      注册      

在组件中使用

var login={      template:'

登录组件---{{$route.params.id}}

', created(){ console.log(this.$route.params.id) } }

路由嵌套的实现

                           
Account

主要是由children属性来实现的,上述代码中由三个易错点

1.定义路由时,子路由没有'/'

2.在父组件中定义子组件要写子组件的全路径

3.在父组件中定义组件同样要加入router-view元素

案例:路由命名视图实现经典布局

命名视图在定义路由时使用components属性(注意不是component)来定义:

var routerObj = new VueRouter({      routes:[      //此处的component只能使用组件对象,而不能使用注册的模板的名称        {path:"/",components:{          default:header,          left:leftBox,          main:mainBox        }},      ]    })

几个组件分别定义如下

var header={      template:'

头部区域

' } var leftBox={ template:'

左部菜单区域

' } var mainBox={ template:'

主体内容区域

' }

我们在页面上使用上述命名视图时使用router-view的name属性来定义

未使用命名属t性name设置视图组件的将采用default命名视图

设置一下样式

  

关于"Vue-Router如何用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

组件 路由 对象 路径 登录 页面 内容 模板 名称 元素 方式 样式 参数 按钮 视图 属性 标签 代码 区域 实例 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 威海联通dns服务器地址 翟银亮南京锦溪网络技术有限公司 国动网络技术 招聘信息 泉州财务软件开发哪个好 服务器属于信息安全产品 值得信赖的嵌入式软件开发 新基建网络安全 微服务一个模块搭建多少台服务器 T430i带网络安全模式 数据库的安全管理包括 浅谈计算机网络技术的发展 服务器空间划分管理方法 黑马网络技术培训机构在哪里 软件开发最重要的考核指标 数据库工程师的职责内容 2022年度网络安全国家标准 网络安全数字化项目 数据库建表时控制男女 服务器mgmt口是干嘛的 智能制造网络安全培训总结 商品管理信息数据库设计 保障全市供电系统网络安全 网鼎杯网络安全大赛比赛 数据库文件无法存放 计算机网络技术施晓秋第三版 711管理器服务器 请联系服务器管理人员是什么意思 网络安全靠人民策划书 中学生能学软件开发吗 计算机网络技术与信息系统
0