需求: 根據環境變量不同控制是否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>
<% } %>
}