差異化打包:控制是否cdn資源引入

需求: 根據環境變量不同控制是否cdn資源引入。
項目背景:vue lic 3
主要是使用webpack配置屬性externals來實現。externals屬性會從輸出的 bundle 中排除依賴。我們需要在package.json中依然添加入依賴。然後通過環境變量動態控制external屬性。同時在public/index.html中通過jsp 動態控制cdn加載。
代碼:
package.json:

"dependencies": {
		"element-ui": "^2.12.0"
		}

vue.config.js:

configureWebpack: config => {
	const externalsConfig = {
            'element-ui': 'ELEMENT'
        };
        config.externals = process.env.NODE_ENV === 'dev'? {} : externalsConfig; // 配置CDN使用
}

public/index.html:

configureWebpack: config => {
	<% if (process.env.NODE_ENV !== 'dev') { %>
	  <script src="https://cdnjs.cloudflare.com/ajax/libs/element-ui/2.12.0/index.js"></script>
	  <% } %>
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章