關(guān)于ant-design-vue使用的優(yōu)化配置

目前在項目中使用了ant-design-vue組件庫,官方有對其配置按需加載功能,但是在實際使用用過程中,很多沒有使用的組件還是被打包進(jìn)了項目牙勘,主要集中在@ant-design/iconsmoment上所禀,占用了很大的體積

先配置組件的按需加載功能

<!--安裝按需引入插件-->
yarn add babel-plugin-import -D

<!-- babel.config.js -->
module.exports = {
  presets: [
    [
      '@vue/cli-plugin-babel/preset',
      { useBuiltIns: 'entry', modules: 'commonjs' }
    ]
  ],
  plugins: [
    <!--ant-design-vue按需加載配置-->
    [
      'import',
      { libraryName: 'ant-design-vue', libraryDirectory: 'es', style: 'css' },
      'ant-design-vue'
    ],
    <!--lodash按需加載配置-->
    'lodash'
  ]
}

我們先上圖看看不做處理的情況下的大蟹矫妗:

moment插件


image

@ant-design/icons


image

現(xiàn)在開始著手解決這些冗余的代碼

moment處理方式:

1、在vue.config.js中使用externals配置排除掉moment

module.exports = {
    ...
    configureWebpack:{
        externals:['moment']
    }
    
}

結(jié)果代碼運(yùn)行報錯色徘,提示找不到moment,應(yīng)該是ant-design-vue中有強(qiáng)依賴該插件恭金,所以這個處理方式走不通,然后度娘了一下褂策,找到了可以通過webpack中自帶的插件減小引用文件的體積

const webpack = require('webpack')
module.exports = {
    ...
    configureWebpack:{
        ...
        plugins:[
            new webpack.ContextReplacementPlugin(/moment[/\\]locale$/, /zh-cn/)
        ]
    }
    
}
image

對比Gzip下體積減少了50KB,效果非常明顯

@ant-design/icons處理方式:

目前官方已經(jīng)在著手解決字體圖標(biāo)的按需加載功能横腿,具體時間未知

我們先看看廣大網(wǎng)友給出的一個很實用的解決方式吧

第一步:在項目中新建一個文件js文件

<!--icons.js-->

<!--如果項目中需要使用@ant-design的字體圖標(biāo)的情況-->
export { default as DoubleRightOutline } from '@ant-design/icons/lib/outline/DoubleRightOutline'
export { default as DoubleLeftOutline } from '@ant-design/icons/lib/outline/DoubleLeftOutline'

<!--不使用的情況-->
export {}

第二步:在vue.config.js中配置

const path = require('path')
module.exports = {
    ...
    configureWebpack:{
        ...
        resolve:{
            alias: {
                '@ant-design/icons/lib/dist$': path.resolve(__dirname,'./src/tools/icons.js')  // 自建的文件的相對路徑
            }
        }
    }
    
}

我的項目中沒有使用@ant-design/icons,所以build之后就看不到這個模塊了,最終的結(jié)果如下:

image

對比一下處理前后的整體項目的Gzip模式下的實際效果:

處理前:

image

處理后:

image

項目整體的大小減少了一半斤寂,??????

順便在提醒一下耿焊,如果項目中沒有使用loadsh,但是依賴的npm包中有使用,最好在項目中安裝一下loadsh的按需引入配置遍搞,你會發(fā)現(xiàn)體積又變小了一點搀别,可能是某些npm依賴中全部引入loadsh

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市尾抑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蒂培,老刑警劉巖再愈,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異护戳,居然都是意外死亡翎冲,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門媳荒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來抗悍,“玉大人,你說我怎么就攤上這事钳枕〗稍ǎ” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵鱼炒,是天一觀的道長衔沼。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么指蚁? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任菩佑,我火速辦了婚禮,結(jié)果婚禮上凝化,老公的妹妹穿的比我還像新娘稍坯。我一直安慰自己,他們只是感情好搓劫,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布瞧哟。 她就那樣靜靜地躺著,像睡著了一般糟把。 火紅的嫁衣襯著肌膚如雪绢涡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天遣疯,我揣著相機(jī)與錄音雄可,去河邊找鬼。 笑死缠犀,一個胖子當(dāng)著我的面吹牛数苫,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辨液,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼虐急,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了滔迈?” 一聲冷哼從身側(cè)響起止吁,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎燎悍,沒想到半個月后敬惦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡谈山,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年俄删,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片奏路。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡畴椰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鸽粉,到底是詐尸還是另有隱情斜脂,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布潜叛,位于F島的核電站秽褒,受9級特大地震影響壶硅,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜销斟,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一庐椒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蚂踊,春花似錦约谈、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至涝动,卻和暖如春迈勋,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背醋粟。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工靡菇, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人米愿。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓厦凤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親育苟。 傳聞我的和親對象是個殘疾皇子较鼓,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353