珠峰培训,专注前端

一、 导航守卫

导航是什么?

导航:“导航”表示路由正在发生改变。

为什么使用导航守卫

真实的项目中需要判断权限或者登录状态决定用户能访问的路由,但是因为路由是在浏览器地址栏中的,用户可以输入,如果不加以拦截就可以看到本不该看到的页面;为了避免这种情况,我们需要使用导航守卫,在路由发生变化时作出相应的判断,判断用户是否可以去到他想去往的页面的路由;

常用的导航守卫:

  1. let router = new VueRouter({....});

1. 全局前置守卫

  1. router.beforeEach((to, from, next) => {....})

当一个路由发生变化时(从一个页面跳到另一个页面时),就会触发 beforeEach 中得回调函数,该回调函数有三个参数:

  1. to 路由对象,即将进入的页面的路由信息
  2. from 路由对象,当前正要离开页面路由信息
  3. next 函数,交出控制权或者中断导航
    • 3.1 next() 交出控制权,执行下面的功能
    • 3.2 next(false) 中断当前导航,如果url改变了,将会回退到当前页面
    • 3.3 next(‘/‘) 跳转到另一个路由,next 可以接收和 $router.push() 一样的参数
  • 当使用导航守卫时,无论是否通过验证,都要调用 next 方法,如果通过校验则执行 next() ,不通过则重定向或者中断;如果不调用,那么整个路由变化处于挂起状态,无法渲染任何组件;

2. 路由独享守卫

  • 你可以在路由配置上直接定义 beforeEnter 守卫;
  1. export default new Router({
  2. routes: [
  3. {
  4. path: '/',
  5. name: 'home',
  6. component: Home
  7. },
  8. {
  9. path: '/about',
  10. name: 'about',
  11. component: () => import(/* webpackChunkName: "about" */ './views/About.vue'),
  12. beforeEnter (to, from, next) {
  13. console.log(to)
  14. console.log(from)
  15. next()
  16. }
  17. }
  18. ]
  19. })
  • beforeEnter 方法同样有三个参数,其3个参数和全局守卫的三个参数相同,在进入该路由组件之前都会调用该钩子,我们在这个钩子中进行校验,如果校验通过,则执行 next(),只有执行 next,才能渲染该路由对应的组件;

3.组件内守卫

最后,你可以在路由组件内直接定义以下路由导航守卫;

  • beforeRouteEnter 在渲染该组件的对应路由前调用,该钩子中不能访问this,因为实例还未创建
  • beforeRouteUpdate 在当前路由改变,但是该组件被复用时调用,适用于动态路由的参数发生变化时
  • beforeRouteLeave 导航离开该组件的对应路由时调用,即要从当前页面去往其他页面时调用,可以用来做保存拦截,例如提示用户信息尚未保存等;
  1. export default {
  2. template: `...`,
  3. beforeRouteEnter (to, from, next) {
  4. // 在渲染该组件的对应路由前调用
  5. // 不!能!获取组件实例 `this`
  6. // 因为当守卫执行前,组件实例还没被创建
  7. },
  8. beforeRouteUpdate (to, from, next) {
  9. // 在当前路由改变,但是该组件被复用时调用
  10. // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
  11. // 由于会渲染同样的组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
  12. // 可以访问组件实例 `this`
  13. },
  14. beforeRouteLeave (to, from, next) {
  15. // 导航离开该组件的对应路由时调用
  16. // 可以访问组件实例 `this`
  17. }
  18. }

二、用webpack配置vue的单页面应用

真实项目中我们不是单独使用 Vue,而是结合 webpack 等打包工具;因为 webpack 可以更方便的实现模块化,导入导出依赖。而且使用 webpack 配合 vue-loader,我们的组件可以写成 .vue 的文件。

使用配置 Vue 应用的 webpack

在之前的 webpack 配置基础上增加 vue-loader 和一个 vue-loader 的插件;

安装 vue-loader、vue-template-compiler

  1. npm install vue-loader vue-template-compiler --save-dev

示例配置文件

  1. let HtmlWebpackPlugin = require('html-webpack-plugin');
  2. const VueLoaderPlugin = require('vue-loader/lib/plugin');
  3. // 使用 vue-loader 需要:
  4. // 1. 安装 vue-template-compiler
  5. // 2. 使用 VueLoaderPlugin
  6. module.exports = {
  7. entry: './src/main.js',
  8. output: {
  9. path: __dirname + './dist',
  10. filename: 'bundle.js'
  11. },
  12. devtool: 'eval-source-map',
  13. devServer: {
  14. contentBase: './src/index.html',
  15. historyApiFallback: true, // 单页面应用路由切换时不请求服务器
  16. port: 8081,
  17. inline: true,
  18. proxy: {
  19. '/api': {
  20. target: 'http://localhost:8000',
  21. changeOrigin: true,
  22. secure: false
  23. }
  24. }
  25. },
  26. module: {
  27. rules: [
  28. {
  29. test: /\.js$/,
  30. use: {
  31. loader: 'babel-loader',
  32. options: {
  33. presets: ['env']
  34. }
  35. },
  36. exclude: /node_modules/
  37. },
  38. {
  39. test: /\.css$/,
  40. use: ['style-loader', 'css-loader']
  41. },
  42. {
  43. test: /\.less$/,
  44. use: ['style-loader', 'css-loader', 'less-loader']
  45. },
  46. {
  47. test: /\.(png|jpg|gif|woff|ttf)$/,
  48. use: 'url-loader'
  49. },
  50. {
  51. test: /\.vue$/,
  52. use: 'vue-loader'
  53. }
  54. ]
  55. },
  56. plugins: [
  57. new HtmlWebpackPlugin({
  58. template: './src/index.html'
  59. }),
  60. new VueLoaderPlugin()
  61. ]
  62. };

三、vue-cli

vue-cli 是 Vue 官方提供的脚手架,其中内置了 webpack 的一些默认配置,可以快速搭建项目;目前市面上常见的版本主要有 2.x 和 3.x;3.x 是最新版本,我们以最新版本为例;

3.1 安装

  • 全局安装 @vue/cli 脚手架
  1. npm install @vue/cli -g

执行 vue —version 输出版本号即为成功

3.2 安装后初始化项目

  1. 在任意目录下(不要有中文名字)打开命令行
  2. 数据 vue create 项目名字,如 vue create my-app
  3. 接下来按照提示按照选择依赖包或者选择默认,一般我们选择手动配置;
  4. 接着等待依赖安装
  5. cd my-app
  6. npm run serve

3.3 修改vue-cli、webpack的配置

  1. 在项目目录下新建 vue.config.js 文件
  2. 一些常见的修改
  1. module.exports = {
  2. outputDir: '../dist', // 在打包输出后的路径
  3. lintOnSave: true, // 默认值 true 启用 ESLint 语法检查
  4. productionSourceMap: false, // 生产环境是否需要 source-map 如果设为 false 可以加速打包
  5. devServer: { // vue-cli 支持所有的 dev-server 配置,
  6. port: 8082,
  7. open: true,
  8. proxy: {
  9. '/api': {
  10. target: 'http://localhost:8000',
  11. changeOrigin: true,
  12. secure: false
  13. }
  14. }
  15. }
  16. };

四、element-ui 使用

4.1 安装 element-ui

  1. npm install element-ui --save

4.2 全局导入 element-ui

  • 在main.js 中导入
  1. import Vue from 'vue';
  2. import ElementUI from 'element-ui'; // 导入 elementUI
  3. import 'element-ui/lib/theme-chalk/index.css'; // 导入 css
  4. import App from './App.vue';
  5. Vue.use(ElementUI);

4.3 使用 element-ui 的组件

  • element-ui 的组件默认全部注册,无需导入,直接使用即可;

示例

  1. <template>
  2. <div class="home">
  3. <el-input v-model="msg" prefix-icon="el-icon-search"></el-input>
  4. </div>
  5. </template>
  6. <script>
  7. export default {
  8. name: 'home',
  9. data() {
  10. return {
  11. msg: ''
  12. }
  13. },
  14. components: {
  15. HelloWorld
  16. }
  17. }
  18. </script>

【发上等愿,结中等缘,享下等福,择高处立,寻平处住,向宽处行】