zoukankan      html  css  js  c++  java
  • 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>
    
  • 相关阅读:
    遗传算法(Genetic Algorithm, GA)及MATLAB实现
    CCF CSP 201809-2 买菜
    PAT (Basic Level) Practice (中文)1008 数组元素循环右移问题 (20 分)
    PAT (Basic Level) Practice (中文)1006 换个格式输出整数 (15 分)
    PAT (Basic Level) Practice (中文)1004 成绩排名 (20 分)
    PAT (Basic Level) Practice (中文)1002 写出这个数 (20 分)
    PAT (Advanced Level) Practice 1001 A+B Format (20 分)
    BP神经网络(原理及MATLAB实现)
    问题 1676: 算法2-8~2-11:链表的基本操作
    问题 1744: 畅通工程 (并查集)
  • 原文地址:https://www.cnblogs.com/zhendiao/p/9589948.html
Copyright © 2011-2022 走看看