vue-router: 路由传参
2018-02-06 10:49
274 查看
路由传参数。在很多时候我们需要路由上面传递参数,比如新闻列表页,我们需要传递新闻ID,给新闻详细页。
1.新闻列表页模板
我们访问
2.新闻详细页组件准备
在js里定义路由组件:
3.定义路由,增加一个路由
访问
4.全部代码如下:
1.新闻列表页模板
<template id="news"> <div> <h2>新闻列表</h2> <ul> <li> <router-link to="/news/001">新闻001</router-link> </li> <li> <router-link to="/news/002">新闻002</router-link> </li> </ul> </div> </template>
我们访问
/news/001,跳转到新闻详细页,展示001的这条新闻。
2.新闻详细页组件准备
<template id="NewsDetail"> <div> 新闻详细页面 <span>{{$route.params.id}}</span> </div> </template>
$route.params.id获取路由上的参数
在js里定义路由组件:
//新闻详细页组件 const NewsDetail = { template: '#NewsDetail' };
3.定义路由,增加一个路由
{ path: '/news/:id', component: NewsDetail },
访问
/news/001或者
/news/002就展示新闻详细页
4.全部代码如下:
<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">
<script src="http://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
</head>
<body>
<div id="box">
<p>
<router-link to="/home">home</router-link>
<router-link to="/news">news</router-link>
</p>
<router-view></router-view>
</div>
<!-- 模板抽离出来 -->
<template id="home">
<!-- 注意:组件只能有一个根元素,所以我们包装到这个div中 -->
<div>
<h2>首页</h2>
<router-link to="/home/login">登录</router-link>
<router-link to="/home/reg">注册</router-link>
<!-- 路由匹配到的组件将渲染在这里 -->
<router-view></router-view>
</div>
</template>
<template id="news">
<div>
<h2>新闻列表</h2>
<ul>
<li>
<router-link to="/news/001">新闻001</router-link>
</li>
<li>
<router-link to="/news/002">新闻002</router-link>
</li>
</ul>
</div>
</template>
<template id="login">
<div>登录界面</div>
</template>
<template id="reg">
<div>注册界面</div>
</template>
<template id="NewsDetail">
<div>
新闻详细页面
<span>{{$route.params.id}}</span>
</div>
</template>
<script type="text/javascript">
// 1. 定义(路由)组件。
const Home = { template: '#home' };
const News = { template: '#news' };
const Login = { template: '#login' };
const Reg = { template: '#reg' };
//新闻详细页组件 const NewsDetail = { template: '#NewsDetail' };
// 2. 定义路由
const routes = [
{ path: '/', redirect: '/home' },
{
path: '/home',
component: Home,
children:[
{ path: '/home/login', component: Login},
{ path: '/home/reg', component: Reg}
]
},
{ path: '/news', component: News,},
{ path: '/news/:id', component: NewsDetail },
]
// 3. 创建 router 实例,然后传 `routes` 配置
const router = new VueRouter({
routes // (缩写)相当于 routes: routes
})
// 4. 创建和挂载根实例。
// 记得要通过 router 配置参数注入路由,
// 从而让整个应用都有路由功能
const app = new Vue({
router
}).$mount('#box')
// 现在,应用已经启动了!
</script>
</body>
</html>
相关文章推荐
- vue-router路由懒加载
- vue-router 路由
- vue从入门到进阶:vue-router路由功能(九)
- vue-router命名路由
- vue-router路由
- 讲解vue-router之什么是嵌套路由
- Vue-router路由判断页面未登录跳转到登录页面
- 前端框架Vue(2)——Vue-Router 路由跳转
- Vue.js路由组件vue-router的使用方法
- vue + vue-router路由视图命名+路由嵌套
- vue-router实现单页面路由原理
- vue-router在同一个路由下切换,取不到变化的路由参数
- Vue.js搭建路由报错 router.map is not a function,Cannot read property ‘component’ of undefined
- vue-router+vuex addRoutes实现路由动态加载及菜单动态加载
- vue通过 vue.mixin(混合)实现 任意页面记录滚动条位置(路由router.query参数一致) 并跳转到上次的位置
- vue-router路由的基础使用
- 讲解vue-router之命名路由和命名视图
- Vue + Vue-router 同名路由切换数据不更新的方法
- 解决element-ui中el-menu组件作为vue-router模式在刷新页面后default-active属性与当前路由页面不一致问题的方法
- Vue-Router的路由实例构造配置