Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)

一、整合 Element UI

1.1 工程初始化

        使用管理员的模式进入 cmd 的命令行模式,创建一个名为 hello-vue 的工程,命令为:

# 1、目录切换
cd F:\idea_home\vue

# 2、项目的初始化,记得一路的 no
vue init webpack hello-vue

1.2 安装依赖

        我们需要安装 vue-routerelement-uisass-loader node-sass 四个插件

# 1、进入工程目录
cd hello-vue

# 2、安装 vue-router
npm install i [email protected] --save-dev

# 3、安装 element-ui
npm i element-ui -S

# 4、安装工程依赖
npm install

# 5、安装 NODE-SASS 加载器
cnpm install [email protected] --save-dev

# 6、按照 SASS-LOADER
cnpm install [email protected] --save-dev

# 7、启动测试
npm run dev

1.3 npm 命令解释

        npm install moduleName:安装模块到项目目录下

        npm install -g moduleName:意思是将模块安装到全局,具体安装到磁盘哪个位置要看 npm config prefix 的位置。

        npm install -save moduleName:--save 的意思是将模块安装到项目目录下,并在 package 文件的 dependencies 节点写入依赖,-S 为该命令的缩写。

        npm install -save-dev moduleNam e:--save-dev 的意思是将模块安装到项目目录下,并在 package 文件的 devDependencies 节点写入依赖,-D 为该命令的缩写。

1.4 删除文件和目录

        删除掉生成的基础工程的配置文件,目录结构和文件内容如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第1张图片



import Vue from 'vue'
import App from './App'

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  components: { App },
  template: ''
})

1.5 创建 views 组件

        在 src 目录下创建 views 文件夹来存储视图类的组件,在 views 文件夹下创建两个组件: Main.vue 组件来充当首页和 Login.vue 组件来充当登录页,内容如下所示:










1.6 创建 router 路由        

        在 src 目录下创建 router 文件夹用于存储路由的配置信息,并在 router 文件夹里创建 index.js 来配置路由信息 ,内容如下所示:

import Vue from 'vue'
import Router from 'vue-router'
import Main from '../views/Main'
import Login from '../views/Login'

Vue.use(Router);

export default new Router({
  routes:[
    {
      path:'/main',
      component:Main
    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

1.7 修改 main.js 和App.vue 

        修改 main.js 文件,将路由信息配置进去

import Vue from 'vue'
import App from './App'
import router from './router'

// 官方规定的引入写法
import ElementUI from "element-ui";
import 'element-ui/lib/theme-chalk/index.css'

Vue.use(router);
Vue.use(ElementUI)

new Vue({
  el: '#app',
  router,
  render: h => h(App)
})

        修改 App.vue,添加路由的组件信息,内容如下所示:


1.8 测试

        启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第2张图片

        在地址栏的后缀输入login 如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第3张图片

        随便输入账号和密码,点击登录,即可跳转到首页,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第4张图片

1.9 总结 

        vue 整合 ElementUI,分为两步:

        第一步:安装依赖

npm i element-ui -S

        第二步: main.js 中写入以下内容:

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import App from './App.vue';

Vue.use(ElementUI);

new Vue({
  el: '#app',
  render: h => h(App)
});

二、路由嵌套

2.1 简介

        嵌套路由又称子路由,在实际应用中,通常由多层嵌套的组件组合而成。同样地,URL 中各段动态路径按某种结构对应嵌套的各层组件,说白了就是 vue 界面的部分内容发生变化,例如:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第5张图片

2.2 创建 user 目录

        在 views 文件夹下新创建一个文件夹 user,并创建两个 vue 组件,List.vue Profile.vue,内容如下所示:






2.3 修改 Main.vue






2.4 修改 router 路由

        需要将新添加的两个 vue 组件配置到 router 的路由里面,即修改 router 文件夹下的 index.js,内容如下所示:

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'

Vue.use(Router);

export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        { path:'/user/list',component:List},
        { path:'/user/profile',component:Profile}
      ]

    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

2.5 测试

   启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第6张图片

        在地址栏的后缀输入 main 如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第7张图片

三、参数传递

3.1 修改 App.vue 






3.2 修改 router 路由

        修改 router 文件夹下的 index.js,内容如下所示:

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'

Vue.use(Router);

export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile
        }
      ]

    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

3.3 修改 Profile.vue 文件



3.4 测试

   启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第8张图片

         在地址栏的后缀输入 main 如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第9张图片

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第10张图片

3.5 第二种传参方式

        App.vue 内容不用改动,修改 router 目录下的 index.js 内容如下所示:

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'

Vue.use(Router);

export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 第一种方式:使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile,
          // 第二种方式:使用 props 来接收参数
          props:true
        }
      ]

    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

        修改 Profile.vue 文件,内容如下所示:




四、重定向

4.1 修改 Main.vue






4.2 修改 router 路由

        修改 router 文件夹下的 index.js,内容如下所示:

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'

Vue.use(Router);

export default new Router({
  routes:[
    {
      path:'/main',
      component:Main,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile,
          props:true
        },
        {
          // 配置重定向信息
          path:'/goHome',
          redirect:'/main'
        }
      ]

    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

4.3 测试

   启动工程,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第11张图片

         在地址栏的后缀输入 main ,显示的内容如下所示,先点击个人信息,再点击回到首页,就可以发现地址栏发生了跳转。

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第12张图片

五、显示当前登录的用户姓名

5.1 修改 Login.vue






5.2 修改 router 路由

        修改 router 文件夹下的 index.js,内容如下所示:

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'

Vue.use(Router);

export default new Router({
  routes:[
    {
      // 接收 login 传过来的参数
      path:'/main/:name',
      component:Main,
      // 允许接收参数
      props:true,
      // 配置嵌套路由
      children:[
        {
          path:'/user/list',
          component:List
        },
        {
          // 使用:id 进行参数接收
          path:'/user/profile/:id',
          name:'Profile222',
          component:Profile,
          props:true
        },
        {
          // 配置重定向信息
          path:'/goHome',
          redirect:'/main'
        }
      ]

    },
    {
      path:'/Login',
      component:Login
    }
  ]
})

5.3 修改 Main.vue






5.4 测试

        启动工程,网址后缀输入 login,并随便登录,如下所示:

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第13张图片

Vue 整合 Element UI 、路由嵌套、参数传递、重定向、404和路由钩子(五)_第14张图片

六、路由钩子

你可能感兴趣的:(vue,vue.js)