路由:
有点累,懒得手打了
data:image/s3,"s3://crabby-images/a2f05/a2f05e5668808e03db04ed42ff430fce83d2f3f9" alt=""
目的:实现SPA(单页面)应用,实现局部刷新
data:image/s3,"s3://crabby-images/db97a/db97a07e7c3e7b449df37ec9632d0a291f96a564" alt="在这里插入图片描述"
vue-router的理解:
vue的一个插件库,专门用来实现SPA应用。
对SPA应用的理解:
- 单页web应用
- 整个应用只有*一个完整的页面*。
- 点击页面中的导航链接不会刷新页面,只会做页面的局部更新
- 数据需要通过ajax请求获取
路由的理解:
1.什么是路由?
(1) 一个路由就是一组映射关系(key-value)
(2) key为路径,value可能是function或component
2.路由的分类
-
后端路由:
- 理解:value是function,用于处理客户端提交的请求。
- 工作过程:服务器接收到一个请求时,根据请求路径找到匹配的函数来处理请求
-
前端路由:
- 理解:value是component,用于展示页面内容。
- 工作过程:当浏览器的路径改变时,对应的组件就会显示。
data:image/s3,"s3://crabby-images/ad8d9/ad8d9d8d36055c6c953aa258e1a7e52d5321b3a8" alt="在这里插入图片描述"
3.基本使用
-
安装vue-router,命令:npm i vue-router -
应用插件:Vue.use(VueRouter) -
编写router配置项: ? //该文件专门用于创建整个应用的路由器
import VueRouter from "vue-router";
//引入路由组件
import About from '../components/About'
import Home from '../components/Home'
//创建router实例对象,去管理一组一组的路由规则
const router = new VueRouter({
routes:[
{
path:'/about',
component:About
},
{
path:'/home',
component:Home
}
]
})
export default router
-
实现切换(active-class可配置高亮样式) -
指定展示位置 ? <router-view></router-view>
4.注意事项
data:image/s3,"s3://crabby-images/a8c97/a8c97ff944c7df1f7310759ba293fa9b69020fc9" alt="" data:image/s3,"s3://crabby-images/0ecf1/0ecf1d0d9b13d129215ecfb9c914790aa50deb5f" alt="在这里插入图片描述"
-
路由组件通常存放在pages 文件夹,一般组件通常存放在components文件夹。 -
通过切换,”隐藏“了的路由组件默认是被销毁掉的,需要的时候再去挂载。 -
每个组件都有自己的$route 属性,里面存储自己的路由信息。 -
整个应用只有一个router,可以通过组件的$router 属性获取到。
5.路由嵌套
在嵌套路由中的path: ‘aaa’, 不能加 /。
data:image/s3,"s3://crabby-images/07b5d/07b5de8d5e8a8e666a307038c1fccb816ce534a8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/3ca2b/3ca2b3c2703e78b4203634c1bc41fa566f909ae8" alt="在这里插入图片描述"
6.路由传参
一般四五层封顶
query
data:image/s3,"s3://crabby-images/7259d/7259d2138dad9612716bec99f742a226a6318834" alt=""
问号后面是query参数
普通写法:
<router-link :to="`/home/message/detail?id=${m.id}&title=${m.title}`">{{ m.title }}</router-link>
?
对象写法:
data:image/s3,"s3://crabby-images/a0454/a0454995d45f64858ed5d89fe5330f73ff6400ef" alt="在这里插入图片描述"
7.路由命名:
name:‘**’
data:image/s3,"s3://crabby-images/28b7b/28b7bba1064ba9eb1bbc6a10d370b224007d46dc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d246e/d246e750934e6f172e8944c9d8c635b7c0022172" alt="在这里插入图片描述"
无论以后路径怎么变,to指向name永远不用改
8.params(懒死了
data:image/s3,"s3://crabby-images/fcfe8/fcfe8e0717c82d578b11f44f7d763c3e6dbf63ab" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f3886/f3886672c8ed8c1f460198945b75a0259763641d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4457e/4457e7283de533720c88a16ca294ed8d1e279318" alt="在这里插入图片描述"
9.props:
props第一种写法:值为对象,该对象中的所有key-value都会以props的形式传给detail组件。
第二种写法:值为布尔值,若布尔值为真,就会把该路由组件收到的所有params参数,以props的形式传给detail组件
module.exports = {
plugins: [
[‘import’, {
libraryName: ‘vant’,
libraryDirectory: ‘es’,
style: (name) => ${name}/style/less ,
}, ‘vant’]
]
}
|