本文使用@vue/cli 5.0.1创建的vue2工程做的验证,预置数据package.json详见最后,其中后三种方式vue路由懒加载的方式。

之前有个操作window全局函数的时候,使用直接引入的方式,结果并没有执行,原因是这种方式会把所有引入的组件打包成一个js,而这个组件又异步引入了很多其它组件及服务,导致window函数的顺序调整导致了没有执行,改成异步加载的方式之后,window函数又能正确的执行啦。

方式一:普通直接引用的方式

import DemoIndex from '../views/home/index.vue'
import Coma from '../views/home/coma.vue'

export const routes = [
  {
    path: '/home',
    name: 'home',
    component: DemoIndex,
  },
  {
    path: '/coma',
    name: 'coma',
    component: Coma,
  }
]

这种方式会这直接将引入的组件一起打进一个js文件中(这里我用的是app.bundule.js),当引入组件过多的时候,会造成性能问题,如下图

我们也可以通过打包后的report.html来查看效果,如下图(可以通过vue-cli-service build --report命令生成report.html文件)

app.bundle.js中具体的路由代码

方式二:es提案的 import()的方式(打出来的包跟网上有些区别,可能vue/cli版本不一致,请大佬不吝赐教)

export const routes = [
  {
    path: '/home',
    name: 'home',
    component: () => import( /* webpackChunkName: "home" */ '@/views/home/index.vue'),
  },
  {
    path: '/coma',
    name: 'coma',
    component: () => import( /* webpackChunkName: "coma" */ '@/views/home/coma.vue'),
  }
]

从网上其它资料得知,这种方式打包后会生成home.hash.js和coma.hash.js两个js文件,但是我打出来js却跟方式一的相似,把内容打进app.bundle.js,见report.html图

 可以确定的是这种方式是异步加载组件,app.bundle.js中具体的路由代码,如下图

 方式三:resovle=>require方式引入

export const routes = [
  {
    path: '/home',
    name: 'home',
    component: (resolve) => require(['../views/home/index.vue'], resolve)
  },
  {
    path: '/coma',
    name: 'coma',
    component: (resolve) => require(['../views/home/coma.vue'], resolve)
  }
]

打包后生成app.bundle.js,还额外生成一个js文件夹,文件夹包含两个js文件分别对应两个组件,如下图

 report.html图

生成的app.bundle.js中具体的路由代码,如下图

 方式四:webpack 的 require.ensure()方式(这个跟方式三生成后的内容及其相似,不过可以指定生成后的js名称)

export const routes = [
  {
    path: '/home',
    name: 'home',
    component: resolve => require.ensure([], () => resolve(require('../views/home/index.vue')), 'home'),
  },
  {
    path: '/coma',
    name: 'coma',
    component: resolve => require.ensure([], () => resolve(require('../views/home/coma.vue')), 'coma'),
  }
]

打包后生成app.bundle.js,还额外生成一个js文件夹,文件夹包含两个js文件分别对应两个组件,如下图

 report.html图

 生成的app.bundle.js中具体的路由代码,如下图

 package.json

{
  "name": "third-02",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "build-report": "vue-cli-service build --report",
    "lint": "vue-cli-service lint"
  },
  "dependencies": {
    "axios": "^0.19.0",
    "core-js": "^3.8.3",
    "dayjs": "^1.8.36",
    "echarts": "^4.2.1",
    "element-ui": "2.13.2",
    "normalize.css": "^7.0.0",
    "vue": "^2.6.14",
    "vue-router": "^3.5.1",
    "vuex": "^3.6.2"
  },
  "devDependencies": {
    "@babel/core": "^7.12.16",
    "@babel/eslint-parser": "^7.12.16",
    "@vue/cli-plugin-babel": "~5.0.0",
    "@vue/cli-plugin-eslint": "~5.0.0",
    "@vue/cli-plugin-router": "~5.0.0",
    "@vue/cli-plugin-vuex": "~5.0.0",
    "@vue/cli-service": "~5.0.0",
    "eslint": "^7.32.0",
    "eslint-plugin-vue": "^8.0.3",
    "sass": "^1.32.7",
    "sass-loader": "^12.0.0",
    "vue-template-compiler": "^2.6.14"
  }
}

Logo

前往低代码交流专区

更多推荐