美文网首页
day04-vuejs-路由(vue-router)

day04-vuejs-路由(vue-router)

作者: 东邪_黄药师 | 来源:发表于2019-01-27 16:13 被阅读12次
什么是路由:
  1. 后端路由:对于普通的网站,所有的超链接都是URL地址,所有的URL地址都对应服务器上对应的资源;
  2. 前端路由:对于单页面应用程序来说,主要通过URL中的hash(#号)来实现不同页面之间的切换,同时,hash有一个特点:HTTP请求中不会包含hash相关的内容;所以,单页面程序中的页面跳转主要用hash实现;
  3. 在单页面应用程序中,这种通过hash改变来切换页面的方式,称作前端路由(区别于后端路由)。
路由-vue-router路由的基本使用:
1. 安装 vue-router 路由模块:
  <script src="./lib/vue-router-3.0.1.js"></script>
2. 创建一个路由对象

当 导入 vue-router 包之后,在 window 全局对象中,就有了一个 路由的构造函数,叫做 VueRouter
在 new 路由对象的时候,可以为 构造函数,传递一个配置对象

    var routerObj = new VueRouter({
      // route // 这个配置对象中的 route 表示 【路由匹配规则】 的意思
      routes: [ // 路由匹配规则 
         // { path: '/', component: login },
        { path: '/', redirect: '/login' }, // 这里的 redirect 和 Node 中的 redirect 完全是两码事
        { path: '/login', component: login },
        { path: '/register', component: register }
      ],
      linkActiveClass: 'myactive'
    }

每个路由规则,都是一个对象,这个规则对象,身上,有两个必须的属性:
属性1 是 path, 表示监听 哪个路由链接地址;
属性2 是 component, 表示,如果 路由是前面匹配到的 path ,则展示 component 属性对应的那个组件
注意: component 的属性值,必须是一个 组件的模板对象, 不能是 组件的引用名称;

3.将路由规则对象,注册到 vm 实例上,用来监听 URL 地址的变化,然后展示对应的组件
// 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {},
      methods: {},
      router: routerObj
    });
4.在页面中放入容器(vue-router):

这是 vue-router 提供的元素,专门用来 当作占位符的,将来,路由规则,匹配到的组件,就会展示到这个 router-view 中去
所以: 我们可以把 router-view 认为是一个占位符

 <!-- 3. 使用 router-view 组件来显示匹配到的组件 -->
<router-view></router-view>
5.router-link的使用:

router-link 默认渲染为一个a 标签可以用tag属性更改

    <router-link to="/login" tag="span">登录</router-link>
    <router-link to="/register">注册</router-link>
6.redirect重定向的使用:

这里的 redirect 和 Node 中的 redirect 完全是两码事

  { path: '/', redirect: '/login' },
7.设置路由高亮的两种方式:

7.1.使用vue本身提供的类名修改样式:

<style>
    .router-link-active{
      color: red;
      font-weight: 800;
      font-style: italic;
      font-size: 80px;
      text-decoration: underline;
      background-color: green;
    }
  </style>

7.2.在创建的router内修改类名实现:


image.png
<style>
  .myactive {
      color: red;
      font-weight: 800;
      font-style: italic;
      font-size: 80px;
      text-decoration: underline;
      background-color: green;
    }

  </style>

在路由规则中定义参数:

方式1(使用(query)方式传递参数):

优点:如果在路由中,使用 查询字符串,给路由传递参数,则 不需要修改 路由规则的 path 属性

<div id="app">
    <router-link to="/login?id=10&name=zs">登录</router-link>
    <router-link to="/register">注册</router-link>
    <router-view></router-view>
  </div>

js:

 <script>

    var login = {
      template: '<h1>登录 --- {{ $route.query.id }} --- {{ $route.query.name }}</h1>',
      data(){
        return {
          msg: '123'
        }
      },
      created(){ // 组件的生命周期钩子函数
        console.log(this.$route)
         console.log(this.$route.query.id)
      }
    }

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

    var router = new VueRouter({
      routes: [
        { path: '/login', component: login },
        { path: '/register', component: register }
      ]
    })

    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {},
      methods: {},
      // router: router
      router
    });
  </script>
image.png
2.使用(params)方式传递参数:

传值:

 <div id="app">
    <router-link to="/login/12/ls">登录</router-link>
    <router-link to="/register">注册</router-link>
     <router-view></router-view>
 </div>

<script>

    var login = {
      template: '<h1>登录 --- {{ $route.params.id }} --- {{ $route.params.name }}</h1>',
      data(){
        return {
          msg: '123'
        }
      },
      created(){ // 组件的生命周期钩子函数
        console.log(this.$route.params.id)
      }
    }

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

    var router = new VueRouter({
      routes: [
        { path: '/login/:id/:name', component: login },
        { path: '/register', component: register }
      ]
    })

    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: '#app',
      data: {},
      methods: {},
      // router: router
      router
    });
  </script>
使用 children 属性实现路由嵌套:
 <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>

使用 children 属性,实现子路由,同时,子路由的 path 前面,不要带 / ,否则永远以根路径开始请求,这样不方便我们用户去理解URL地址

image.png
路由-命名视图(使用name属性):

css:

 <style>
.header {
  border: 1px solid red;
}

.content{
  display: flex;
}
.sidebar {
  flex: 2;
  border: 1px solid green;
  height: 500px;
}
.mainbox{
  flex: 8;
  border: 1px solid blue;
  height: 500px;
}
</style>

2.标签代码结构:

<div id="app">
     <router-view></router-view>
<div class="content">
     <router-view name="a"></router-view>
     <router-view name="b"></router-view>
</div>
</div>

3js:

 <script>
var header = Vue.component('header', {
  template: '<div class="header">header</div>'
});

var sidebar = Vue.component('sidebar', {
  template: '<div class="sidebar">sidebar</div>'
});

var mainbox = Vue.component('mainbox', {
  template: '<div class="mainbox">mainbox</div>'
});

// 创建路由对象
var router = new VueRouter({
  routes: [
    {
      path: '/', components: {
        default: header,
        a: sidebar,
        b: mainbox
      }
    }
  ]
});

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

</script>

相关文章

  • day04-vuejs-路由(vue-router)

    什么是路由: 后端路由:对于普通的网站,所有的超链接都是URL地址,所有的URL地址都对应服务器上对应的资源; 前...

  • 手写 Vue Router、手写响应式实现、虚拟 DOM 和 D

    Vue-Router 原理实现 一、Vue-Router 动态路由 二、Vue-Router 嵌套路由 三、Vue...

  • vue-router学习总结

    1.引入vue-router npm install vue-router --save 2.设置路由(1)路由实...

  • 2018-09-24 vue.js vue-router

    vue-router Vue路由器 Git 安装 npm install vue-router 路由中有三个...

  • 路由

    路由map 路由视图 路由导航 实现简单路由 import VueRouter from 'vue-router'...

  • vue路由

    路由:vue-router 案例: 1.路由 2.路由的嵌套

  • Vue 基础 - 前端路由

    使用vue-router实现前端路由 安装vue-router: 配置路由文件,并在vue实例中导入: 设置视图(...

  • 10. vue-router 路由详解

    vue2有着深度继承的路由插件,即:vue-router,其中文的API地址。 vue-router与其他的路由(...

  • 一起学Vue:路由(vue-router)

    前言 学习vue-router就要先了解路由是什么?前端路由的实现原理?vue-router如何使用?等等这些问题...

  • vue-router用法记录

    Vue-Router简介 Vue-Router是Vue.js官方维护的路由插件,同时也是官方推荐的路由插件。它与V...

网友评论

      本文标题:day04-vuejs-路由(vue-router)

      本文链接:https://www.haomeiwen.com/subject/bxhbjqtx.html