vue 笔记(十七) 404和路由钩子

一、路由的模式有两种

  • hash:路径带 # 符号 
  • history:路径不带 # 符号

要改成不带#符号的,先修改路由的配置 index.js 如下:

export default new Router({
  mode:'history',
  routes:[]
});

然后运行:

vue 笔记(十七) 404和路由钩子_第1张图片

可以看到不带# 符号了

二、404的处理

1.先创建一个名为 NotFound.vue 的视图组件

vue 笔记(十七) 404和路由钩子_第2张图片

代码如下:






2. 配置路由 index.js,将此 NotFound 组件导进来 

import Vue from 'vue'
import Router from 'vue-router'

import Main from "../views/Main";
import Login from "../views/Login";

import List from "../views/user/List";
import Profile from "../views/user/Profile";
import NotFound from "../views/NotFound"; 

Vue.use(Router);

export default new Router({
  mode:'history',
  routes:[
    {
      path:'/main',
      name:'main',
      component:Main,
      children:[
        {
          path:'/user/profile/:id/:name',
          name:'UserProfile',
          // 支持传递参数
          props:true,
          component:Profile
        },
        {
          path: '/user/list',
          component: List
        }
      ]
    },
    {
      path:'/login',
      name: 'login',
      component:Login
    },
    {
      path: '/goHome',
      redirect:'/main'
    },
    {
      path: '*',
      component: NotFound   ///
    }
  ]
})

3.运行效果:

vue 笔记(十七) 404和路由钩子_第3张图片

三、将登录页面与main页面串起来

1.先在Login.vue 中 将表单中的用户名 传到Main.vue 中

methods: {
      onSubmit(formName) {
        // 为表单绑定验证功能
        this.$refs[formName].validate((valid) => {
          if (valid) {
            // 使用 vue-router 路由到指定页面,该方式称之为编程式导航
            this.$router.push("/main/"+this.form.username);
          } else {
            this.dialogVisible = true;
            return false;
          }
        });
      }
    }

2. 修改路由配置 index.js 

export default new Router({
  mode:'history',
  routes:[
    {
      path:'/main/:name', /
      name:'main',
      props:true,     /
      component:Main,
       ...
       ...
     }
         】
})

3. 在 Main.vue 中 接收 name 参数   加上span 标签


        
          
            
            
              个人信息
              退出登录
            
          

          {
    {name}}       
        
        
          
          
        
      

...
...
...


4.运行结果:

vue 笔记(十七) 404和路由钩子_第4张图片

vue 笔记(十七) 404和路由钩子_第5张图片

四、路由钩子和axios异步请求

  • beforeRouteEnter:在进入路由前执行
  • beforeRouteLeave:在离开路由前执行

1.在Profile.vue 里写

to:路由将要跳转的路径信息
from:路径跳转前的路径信息
next:路由的控制参数
next() 跳入下一个页面
next(’/path’) 改变路由的跳转方向,使其跳到另一个路由
next(false) 返回原来的页面
next((vm)=>{}) 仅在 beforeRouteEnter 中可用,vm 是组件实例

运行后,点击个人信息,再点击用户列表,控制台会打印:

2.在钩子函数中使用Axios

先安装Axios   去官网 http://www.axios-js.com/

cnpm install --save vue-axios

在 main.js 中引入 

import axios from 'axios'
import VueAxios from 'vue-axios'

Vue.use(VueAxios, axios)

准备数据 ,在static 中新建目录mock ,mock 中新建 data.json

{
  "name":"swk",
  "url": "http://baidu.com",
  "page": 1,
  "isNonProfit":true,
  "address": {
    "street": "勤俭道",
    "city":"天津",
    "country": "中国"
  },
  "links": [
    {
      "name": "B站",
      "url": "https://www.bilibili.com/"
    },
    {
      "name": "4399",
      "url": "https://www.4399.com/"
    },
    {
      "name": "百度",
      "url": "https://www.baidu.com/"
    }
  ]
}

运行访问一下结果:

vue 笔记(十七) 404和路由钩子_第6张图片

然后在 beforeRouteEnter 中进行异步请求

  

  

  

运行结果:

vue 笔记(十七) 404和路由钩子_第7张图片

控制台可以发现获取的json数据

vue 笔记(十七) 404和路由钩子_第8张图片

你可能感兴趣的:(前端)