webpack4和webpack3在vue中動(dòng)態(tài)加載路由的區(qū)別

在webpack3中加載vue動(dòng)態(tài)路由時(shí)是這樣的

function filterAsyncRouter(asyncRouterMap) {
  return asyncRouterMap.filter(route => {

    if (route.component) {
      // Layout組件特殊處理
      if (route.component === 'Layout') {
        route.component = Layout
      } else {
        route.component = loadView(route.component)
      }
    }
    if (route.children != null && route.children && route.children.length) {
      route.children = filterAsyncRouter(route.children)
    }
    return true
  })
}

const loadView = (view) => { // 路由懶加載
    return () => import(`@/views/${view}`)
}

在webpack3中是支持import這樣動(dòng)態(tài)引入路由的。而在webpack4中還使用import的方式引入動(dòng)態(tài)路由則會(huì)報(bào)錯(cuò)了

error

很明顯,告訴我們找不到該模塊了。
PS: 造成這個(gè)情況的原因是webpack4中不在支持import()方法動(dòng)態(tài)引入文件,僅限開(kāi)發(fā)模式,生產(chǎn)模式是正常的,可以繼續(xù)使用import()動(dòng)態(tài)引入

怎么解決?

  1. 使用require方法引入,修改一下loadView方法
const loadView = (view) => { // 路由懶加載
    return resolve => require([`@/views/${view}`], resolve)
}
  1. 使用babel-plugin-dynamic-import-webpack
    a. 安裝npm install babel-plugin-dynamic-import-webpack --save-dev
    b. 配置.babelrc文件或者babel.config.js文件
    .babelrc
    {
        ...
        "plugins": [
          "dynamic-import-webpack"
        ]
        ...
    }
    
    babel.config.js
    module.exports = {
        ...
        presets: [
            ...,
            "dynamic-import-webpack"
        ],
        ...
     }
    

歡迎各位大佬指正錯(cuò)誤。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容