Vue.js 生態之vue-router

vue-router是什麼~~

vue-router是Vue的路由系統,定位資源的,咱們能夠不進行整頁刷新去切換頁面內容。html

vue-router的安裝和基本配置

vue-router.js 能夠下載 也能夠用cdn,基本配置信息看以下代碼~~~vue

// html 代碼
<div id="app">
    <div>
        <router-link to="/">首頁</router-link>
        <router-link to="/about">關於咱們</router-link>
    </div>
    <div>
        <router-view></router-view>
    </div>

</div>

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
<script src="../js/router_demo.js"></script>
// js 代碼
var routes = [
    {
        path: "/",
        component: {
            template: `<div><h1>首頁</h1></div>`
        }
    },
    {
        path: "/about",
        component: {
            template: `<div><h1>關於咱們</h1></div>`
        }
    }
]

var router = new VueRouter({
    routes: routes,
    // 路由去掉#
    // mode: 'history',
});

var app = new Vue({
    el: '#app',
    router: router,
});
vue-router demo

路由的一些方法

路由傳參以及獲取參數~~vue-router

// html 代碼
<div id="app">
    <div>
        <router-link to="/">首頁</router-link>
        <router-link to="/about">關於咱們</router-link>
        <router-link to="/user/琴女?age=20">琴女</router-link>
        <router-link to="/user/提莫">提莫</router-link>
    </div>
    <div>
        <router-view></router-view>
    </div>
</div>
// js 代碼
var routes = [
    {
        path: "/",
        component: {
            template: `<div><h1>首頁</h1></div>`
        }
    },
    {
        path: "/about",
        component: {
            template: `<div><h1>關於咱們</h1></div>`
        }
    },
    {
        path: "/user/:name",
        component: {
            template: `<div>
                      <h1>我是:{{$route.params.name}}</h1>
                      <h1>我年齡是:{{$route.query.age}}</h1>
                    </div>`,
        }
    }
]

var router = new VueRouter({
    routes: routes,
});

var app = new Vue({
    el: '#app',
    router: router,
});
傳參以及獲取參數

命名路由~  注意router-link裏to必定要v-bind~~npm

// html代碼
<div id="app">
    <div>
        <router-link to="/">首頁</router-link>
        <router-link :to="{name: 'about'}">關於咱們</router-link>
        <router-link to="/user/gaoxin?age=19">gaoxin</router-link>
    </div>
    <div>
        <router-view></router-view>
    </div>
</div>
// js代碼
let routes = [
        {
            path: '/',
            component: {
                template: `<h1>這是主頁</h1>`
            }
        },
        {
            path: "/about",
            name: "about",
            component: {
                template: `<h1>關於咱們</h1>`
            }
        },
        {
            path: "/user/:name",
            component: {
                template: `<div>
                            <h1>我是{{$route.params.name}}</h1>
                           <h2>個人年齡是{{$route.query.age}}</h2>
                            </div>
                          `
            }
        }
    ];

    let router = new VueRouter({
        routes: routes,
        mode: "history"
    });

    const app = new Vue({
        el: "#app",
        router: router,
        mounted(){
            console.log(this.$route)
            console.log(this.$router)
        }
    })
命名路由

子路由~~ 以展現詳細爲例~~app

// 添加子路由變化的只有父級路由 
// 基於上面的例子增長
// js 代碼
{
        path: "/user/:name",
        component: {
            template: `<div>
                      <h1>我是:{{$route.params.name}}</h1>
                      <h1>我年齡是:{{$route.query.age}}</h1>
                      <router-link to="more" append>更多信息</router-link>
                      <router-view></router-view>
                    </div>`,
        },
        children: [
            {
            path: "more",
            component: {
                template: `<div>
                      {{$route.params.name}}的詳細信息
                </div>`,
            }
        }
        ]

    },
子路由

 手動訪問路由,以及傳參~~ide

// 基於上面例子追加
// html 代碼
<div id="app">
    <div>
        <router-link to="/">首頁</router-link>
        <router-link to="/about">關於咱們</router-link>
        <router-link to="/user/琴女?age=20">琴女</router-link>
        <router-link to="/user/提莫">提莫</router-link>
        // 添加一個button按鈕
        <button @click="on_click">旅遊</button>
    </div>
    <div>
        <router-view></router-view>
    </div>
</div>    
// js 代碼
// 注意路由name的使用 這是在原例子追加
var app = new Vue({
    el: '#app',
    router: router,
    methods: {
        on_click: function () {
            setTimeout(function () {
                this.$router.push('/about')
                setTimeout(function () {
                    this.$router.push({name: "user", params:{name: "琴女"},query:{age: 20}})
                }, 2000)
            }, 2000)
        }
    }
});
手動路由~以及傳參

命名路由視圖 router-view函數

當咱們只有一個<router-view></router-view>的時候~全部內容都展現在這一個面板裏面~post

若是是content 和 footer 就須要同時顯示而且不一樣區域~這就須要對視圖進行命名~ui

// html 代碼
<div id="app">
    <div>
        <router-link to="/">首頁</router-link>
        
    </div>
    <div>
        <router-view name="content" class="content-view"></router-view>
        <router-view name="footer" class="footer-view"></router-view>
    </div>

</div>
// js 中的主要代碼
var routes = [
    {
        path: "/",
        components: {
            content: {
                template: `<div><h1>首頁</h1></div>`,
            },
            footer: {
                template: `<div><h1>關於咱們</h1></div>`,
            }
        }
    },
]
命名路由視圖

錯誤路由的重定向~~this

let routes = [
     {
            path: "**",
            redirect: "/"
        }   
]
redirect

$route以及$router的區別~~

  -- $route爲當前router調轉對象,裏面能夠獲取name, path, query, params等~

  -- $router爲VueRouter實例,有$router.push方法等~~

路由的鉤子

在路由跳轉的時候,咱們須要一些權限判斷或者其餘操做。這個時候就須要使用路由的鉤子函數

定義:路由鉤子主要是給使用者在路由發生變化時進行一些特殊的處理而定義的函數。

路由的生命週期就是從一個路由跳轉到另外一路由整個過程,下面介紹兩個鉤子~

router.beforeEach()   router.afterEach()  詳情請看代碼~~

// html 代碼
<div id="app">
    <router-link to="/">首頁</router-link>
    <router-link to="/login">登陸</router-link>
    <router-link to="/user">用戶管理</router-link>
    <div>
        <router-view></router-view>
    </div>
</div>
//  js 代碼
var routes = [
    {
        path: "/",
        component: {
            template: "<h1>首頁</h1>"
        }
    },
    {
        path: "/login",
        component: {
            template: "<h1>登陸</h1>"
        }
    },
    {
        path: "/user",
        component: {
            template: "<h1>用戶管理</h1>"
        }
    }
];
var router = new VueRouter({
    routes: routes
});

router.beforeEach(function (to,from,next) {
    // console.log(to)
    // console.log(from)
    // console.log(next)
    // next(false)
    if(to.path=="/user"){
        next("/login")
    }
    else {
        next();
    }
});
router.afterEach(function (to, from) {
    console.log(to)
    console.log(from)
});

var app = new Vue({
    el: '#app',
    router: router
});
路由鉤子
next:function  必定要調用這個方法來resolve這個鉤子函數。
        執行效果依賴next方法的調用參數
        next() 什麼都不作繼續執行到調轉的路由
        next(false) 中斷當前導航 沒有跳轉 也沒有反應
        next("/")  參數是路徑 調轉到該路徑
        next(error)  若是next參數是一個Error實例 導航終止該錯誤
                    會傳遞給router.onError()註冊過的回調中
next 參數詳解
    router.beforeEach(function (to,from,next) {
        console.log(to);
        console.log(from);
        console.log(next);
        next()
    });

後面加   next()

 

上面的例子~~若是/user下面還有子路由的狀況下會怎麼樣呢~????

// 匹配子路由 改一下匹配方法就能夠~
// js 改動代碼
router.beforeEach(function (to,from,next) {
    // console.log(to)
    // console.log(from)
    // console.log(next)
    // next(false)
    if(to.matched.some(function (item) {
            return item.path == "/post"
        })){
        next("/login")
    }
    else {
        next();
    }
});
// 元數據配置 改動代碼
// html 部分
 {
        path: "/user",
        meta: {
            required_login: true,
        },
        component: {
            template: `
                <div>
                <h1>用戶管理</h1>
                <router-link to="vip" append>vip</router-link>
                <router-view></router-view>
                </div>
                `
        },
        children: [{
            path: "vip",
            meta: {
              required_login: true,
            },
            component: {
                template: '<h1>VIP</h1>'
            }
        }]
    }
// js 部分
router.beforeEach(function (to,from,next) {
    // console.log(to)
    // console.log(from)
    // console.log(next)
    // next(false)
    if(to.meta.required_login){
        next("/login")
    }
    else {
        next();
    }
});
匹配子路由以及元數據配置

 在子組件中調用路由的鉤子函數時無效的。

相關文章
相關標籤/搜索