Vue-Router的简单使用

Vue-Router的最简单使用

1.先注册路由

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

3.定义组件

4.页面定义跳转路径

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script src="lib/vue.min.js"></script>
		<script src="lib/vue-router-3.0.1.js"></script>
		<style type="text/css">
		</style>
	</head>
	<body>
		
		<div id="app">
			<!--
            	由于Vue-router的hash匹配原则所以我们需要在原定义的路径上加一个#号
            -->
			<a href="#/login">登录</a>
			<a href="#/register">注册</a>
			<router-view></router-view>
		</div>
	</body>
	<script>
		var login={
			template:'<h1>登录组件</h1>'
		}
		var register={
			template:'<h1>注册组件</h1>'
		}
		var routerObj = new VueRouter({
			routes:[
			//此处的component只能使用组件对象,而不能使用注册的模板的名称
				{path:"/login",component:login},
				{path:"/register",component:register}
			]
		})
		var vm = new Vue({
			el:'#app',
			data:{
			},
			methods:{
				
			},
			router:routerObj//将路由规则对象注册到VM实例上
		})
	</script>
</html>

使用Router-Link替代a标签

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

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script src="lib/vue.min.js"></script>
		<script src="lib/vue-router-3.0.1.js"></script>
		<style type="text/css">
		</style>
	</head>
	<body>
		
		<div id="app">
			<!--
            	由于Vue-router的hash匹配原则所以我们需要在原定义的路径上加一个#号
            -->
<!--			<a href="#/login">登录</a>
			<a href="#/register">注册</a>-->
			<router-link to="/login" tag="span">登录</router-link>
			<router-link to="/register">注册</router-link>
			<router-view></router-view>
		</div>
	</body>
	<script>
		var login={
			template:'<h1>登录组件</h1>'
		}
		var register={
			template:'<h1>注册组件</h1>'
		}
		var routerObj = new VueRouter({
			routes:[
			//此处的component只能使用组件对象,而不能使用注册的模板的名称
				{path:"/login",component:login},
				{path:"/register",component:register}
			]
		})
		var vm = new Vue({
			el:'#app',
			data:{
			},
			methods:{
				
			},
			router:routerObj//将路由规则对象注册到VM实例上
		})
	</script>
</html>

同时,我们还可以利用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中设置

		<style type="text/css">
			.router-link-active{
				color: red;
				font-weight: 800;
				font-style: italic;
				font-size: 30px;
			}
		</style>

使用自定义类名

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

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

指定样式

		<style type="text/css">
			.router-link-active,.myactive{
				color: red;
				font-weight: 800;
				font-style: italic;
				font-size: 30px;
			}
		</style>

路由传参

使用query方式传递参数

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

			<router-link to="/login?id=10&name=zhao">登录</router-link>

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

		var login={
			template:'<h1>登录组件---{{$route.query.id}}--{{$route.query.name}}</h1>',
			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}
			],
		})

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

		<router-link to="/login/10/zhao">登录</router-link>
			<router-link to="/register">注册</router-link>
			<router-view></router-view>

在组件中使用

		var login={
			template:'<h1>登录组件---{{$route.params.id}}</h1>',
			created(){
				console.log(this.$route.params.id)
			}
		}

路由嵌套的实现

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script src="lib/vue-2.4.0.js"></script>
		<script src="lib/vue-router-3.0.1.js"></script>
		<style type="text/css">

		</style>
	</head>
	<body>
  <div id="app">

    <router-link to="/account">Account</router-link>

    <router-view></router-view>

  </div>

  <template id="tmpl">
    <div>
      <h1>这是 Account 组件</h1>

      <router-link to="/account/login">登录</router-link>
      <router-link to="/account/register">注册</router-link>

      <router-view></router-view>
    </div>
  </template>

  <script>

    // 组件的模板对象
    var account = {
      template: '#tmpl'
    }

    var login = {
      template: '<h3>登录</h3>'
    }

    var register = {
      template: '<h3>注册</h3>'
    }

    var router = new VueRouter({
      routes: [
        {
          path: '/account',
          component: account,
          // 使用 children 属性,实现子路由,同时,子路由的 path 前面,不要带 / ,否则永远以根路径开始请求,这样不方便我们用户去理解URL地址
          children: [
            { path: 'login', component: login },
            { path: 'register', component: register }
          ]
        }
}
      ]
    })

    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {},
      methods: {},
      router
    });
  </script>
</body>
</html>

主要是由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:'<h1 class="header">头部区域</h1>'
		}
		var leftBox={
			template:'<h1 class=left>左部菜单区域</h1>'
		}
		var mainBox={
			template:'<h1 class="main">主体内容区域</h1>'
		}

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

		<div id="app">
			<router-view></router-view>
			<div id="container">
				<router-view name="left"></router-view>
				<router-view name="main"></router-view>
			</div>

		</div>

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

设置一下样式

	<style type="text/css">
		html,body{
			margin: 0;
			padding: 0;
		}
		h1{
			margin: 0;
			padding: 0;
			font-size: 16px;
		}
		.header{
			background-color: #6495ED;
			height: 200px;
		}
		
		#container{
			display: flex;
			height: 600px;
		}
		.left{
			flex: 2;
			background-color: #0000FF;
		}
		.main{
			flex: 8;
			background-color: #8A2BE2;
		}
	</style>
posted @ 2018-09-05 07:42  镇屌  阅读(494)  评论(0编辑  收藏  举报