差异化打包:控制是否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>
	  <% } %>
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章