vue-router 按需加载

vue的单页面(SPA)项目,必然涉及路由按需的问题。
之前咱们是这么作的javascript

//require.ensure是webpack里面的,这样作会将单独拉出来做为一个chunk文件
const Login = r => require.ensure( [], () => r (require('../component/Login.vue')));

但如今vue-router的官网看看,推荐这种方式:vue

//vue异步组件和webpack的【代码分块点】功能结合,实现了按需加载
const App = () => import('../component/Login.vue');

但是,不少状况下,咱们这么写npm run dev控制台直接报错,这是为何呢?java

Module build failed: SyntaxError: Unexpected token

原来是import这儿报错了,这就须要babel的插件了,vue-router官网上有一段提示:
若是您使用的是 Babel,你将须要添加 syntax-dynamic-import 插件,才能使 Babel 能够正确地解析语法。
至此,问题所有解决了。webpack

若是使用vue-cli生成项目,极可能在babel-loader没有配置上面的插件,这时须要咱们本身去安装此插件:web

cnpm install babel-plugin-syntax-dynamic-import --save-dev


而后修改webpack的js的loader部分:vue-router

{
test: /\.js$/,
loader:'babel-loader',
options:{
plugins:['syntax-dynamic-import']
},
},

  

增长了option选项,至此,能识别咱们:vue-cli

const App = () => import('../component/Login.vue');

的语法了,页面出来了:
npm

在打包的时候,发现咱们若是只是这么写,出现的chunk包名字都是乱的,若是咱们指定命名,该怎么办呢?webpack3提供了Magic Comments(魔法注释)babel

const App = () => import(/* webpackChunkName:'login'*/ '../component/Login.vue');

 这样咱们就为打包出来的chunk指定一个名字,最终生成login.js的chunk包。异步

相关文章
相关标签/搜索