有的時候咱們不想將第三方的庫打包,想借助於別人的cdn引入。這時就須要externals。
以引入jq爲例(vue以及其餘庫均可以),以及依賴jq的第三方插件:vue
externals: { jquery: 'window.$' },
使用則直接 require 進來,反正 webpack 也不會把它打包進來。jquery
var $ = require('jquery');
依賴jq的插件直接src引入便可。webpack
import { debounce } from 'lodash' import { throttle } from 'lodash' // 改爲以下寫法 import debounce from 'lodash/debounce' import throttle from 'lodash/throttle'
{ path: '/somepath', component: function (resolve) { require(['./demos/somepath.vue'], resolve) } }
假如,你使用的是 Vue,將一個組件(以及其全部依賴)改成異步加載,所須要的只是把:web
import scorerecord from '../views/scorerecord.vue'
改成以下寫法:異步
const scorerecord = () => import('../views/scorerecord.vue')
如此分割之時,該組件所依賴的其餘組件或其餘模塊,都會自動被分割進對應的 chunk 裏,實現異步加載,固然也支持把組件按組分塊,將同組中組件,打包在同個異步 chunk 中。如此可以很是有效的抑制 js包過大。模塊化