zoukankan      html  css  js  c++  java
  • vue-router 按需加载

    vue的单页面(SPA)项目,必然涉及路由按需的问题。
    以前我们是这么做的

    //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没有配置上面的插件,这时需要我们自己去安装此插件:

    npm 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包。

    // 下面2行代码,没有指定webpackChunkName,每个组件打包成一个js文件。
    const ImportFuncDemo1 = () => import('../components/ImportFuncDemo1')
    const ImportFuncDemo2 = () => import('../components/ImportFuncDemo2')
    // 下面2行代码,指定了相同的webpackChunkName,会合并打包成一个js文件。
    const ImportFuncDemo = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/ImportFuncDemo')
    const ImportFuncDemo2 = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/ImportFuncDemo2')
    

     转自:https://www.cnblogs.com/xiaochongchong/p/7772773.html

    https://segmentfault.com/a/1190000011519350

  • 相关阅读:
    SQLSERVER2000使用TSQL将数据导入ACCESS并压缩生成rar
    收回动态VHD的未使用空间
    如何在html中添加引用公共模块文件 bling
    C语言I博客作业02
    C语言I博客作业06
    C语言I博客作业05
    C语言I博客作业04
    C语言I博客作业03
    Kali 安装JAVA(来源:oschina)
    DHCP服务器内网攻击测试
  • 原文地址:https://www.cnblogs.com/hycms/p/9248795.html
Copyright © 2011-2022 走看看