vue-router 按需加载
2017-11-02 16:10
309 查看
vue的单页面(SPA)项目,必然涉及路由按需的问题。
以前我们是这么做的
但现在无Vue-router的官网看看,推荐这种方式:
可是,很多情况下,我们这么写npm控制台直接报错,这是为什么呢?
原来是import这儿报错了,这就需要babel的插件了,vue-router官网上有一段提示:
如果您使用的是 Babel,你将需要添加 syntax-dynamic-import 插件,才能使 Babel 可以正确地解析语法。
至此,问题全部解决了。
如果使用vue-cli生成项目,很可能在babel-loader没有配置上面的插件,这时需要我们自己去安装此插件:
然后修改js的loader部分:
增加了option选项,至此,能识别我们const App = () => import('../component/Login.vue');的语法了,页面出来了:
在打包的时候,发现我们如果只是这么写:const App = () => import('../component/Login.vue');出现的chunk包名字都是乱的,如果我们指定命名,该怎么办呢?webpack3提供了Magic Comments(魔法注释)
这样我们就为打包出来的chunk指定一个名字,最终生成login.js的chunk包。
以前我们是这么做的
//require.ensure是webpack里面的,这样做会将单独拉出来作为一个chunk文件 const Login = r => require.ensure( [], () => r (require('../component/Login.vue')));
但现在无Vue-router的官网看看,推荐这种方式:
//vue异步组件和webpack的【代码分块点】功能结合,实现了按需加载 const App = () => import('../component/Login.vue');
可是,很多情况下,我们这么写npm控制台直接报错,这是为什么呢?
Module build failed: SyntaxError: Unexpected token
原来是import这儿报错了,这就需要babel的插件了,vue-router官网上有一段提示:
如果您使用的是 Babel,你将需要添加 syntax-dynamic-import 插件,才能使 Babel 可以正确地解析语法。
至此,问题全部解决了。
如果使用vue-cli生成项目,很可能在babel-loader没有配置上面的插件,这时需要我们自己去安装此插件:
cnpm install babel-plugin-syntax-dymic-import --save-dev
然后修改js的loader部分:
{ test: /\.js$/, loader:'babel-loader', options:{ plugins:['syntax-dynamic-import'] }, },
增加了option选项,至此,能识别我们const App = () => import('../component/Login.vue');的语法了,页面出来了:
在打包的时候,发现我们如果只是这么写:const App = () => import('../component/Login.vue');出现的chunk包名字都是乱的,如果我们指定命名,该怎么办呢?webpack3提供了Magic Comments(魔法注释)
const App = () => import(/* webpackChunkName:'login'*/ '../component/Login.vue');
这样我们就为打包出来的chunk指定一个名字,最终生成login.js的chunk包。
相关文章推荐
- vue-router路由懒加载(解决vue项目首次加载慢)
- EasyDSS高性能流媒体服务器前端重构(五)- webpack + vue-router 开发单页面前端实现按需加载 - 副本
- Vue-Router 页面正在加载特效
- vue-router懒加载
- EasyDSS高性能流媒体服务器前端重构(五): webpack + vue-router 开发单页面前端实现按需加载
- EasyDSS高性能流媒体服务器前端重构(五)- webpack + vue-router 开发单页面前端实现按需加载
- 【108】Vue-router 2.8.1 懒加载使用Webpack 3 的import() 语句出错的解决办法
- Vue-router懒加载
- vue-router路由懒加载的实现(解决vue项目首次加载慢)
- vue2笔记 ― vue-router路由懒加载的实现
- vue-router路由懒加载
- vuejs 无node单页应用方案二(babel-standalone or traceur,vue-router实现、组件按需懒加载)
- vue+vue-router+vuex,利用vue-router2.2.0新增特性addRoutes实现路由动态加载,菜单动态加载,运用于后台管理系统,路由数据取自数据库
- vue-router路由懒加载和权限控制详解
- 深入浅出的webpack4构建工具---webpack+vue+router 按需加载页面(十五)
- Vue-Router 页面正在加载特效
- vue-router 懒加载优化
- vue-router+vuex addRoutes实现路由动态加载及菜单动态加载
- Vue-Router实现页面正在加载特效方法示例
- 为vue-router懒加载时下载js的过程中添加loading提示避免无响应问题