亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

configureWebpack、chainWebpack配置vue.config.js方式

 更新時間:2024年01月24日 15:46:02   作者:土豆Coder  
這篇文章主要介紹了configureWebpack、chainWebpack配置vue.config.js方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

引入問題

我們使用vue create waf-console-vue創(chuàng)建一個Vue項目時,新生成的項目我們可以看到在public/index.html中有這樣的內(nèi)容:

<title><%= htmlWebpackPlugin.options.title %></title>

Vue CLI 關(guān)于HTML和靜態(tài)資源中有說明:

public/index.html文件是一個會被處理的模板html-webpack-plugin處理的模板。在構(gòu)建過程中,資源鏈接會被自動注入。

所以我們會想到,這里使用變量的形式訪問到的

htmlWebpackPlugin.options.title

也就是我們在創(chuàng)建項目的時候命名的項目名稱,然后被腳手架Vue CLI構(gòu)建項目時自動被處理模板寫入了webpack配置中,那我們要如何修改這個配置項呢?

這就引出了問題:

我們?nèi)绾卧?code>@vue-cli4的vue.config.js文件中修改webpack中的這個配置項?

也就是如何修改這個值

htmlWebpackPlugin.options.title

修改htmlWebpackPlugin.options.title

因為新的腳手架vue不希望我們直接操作webpack配置文件,所以不再提供webpack.dev.js這樣的文件了,如果我們想要修改webpack配置需要手動創(chuàng)建文件vue.config.js,那我們?nèi)绾慰茨J項目已經(jīng)配置好的webpack配置內(nèi)容呢?

vue inspect > output.js

運行后項目中會自動生成一個文件output.js,這個就是當前項目的webpack配置內(nèi)容

紅框中我們看到title就是我們的項目名稱,現(xiàn)在我們要修改這個值

// vue.config.js
module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
  }
}

此時,重新啟動項目npm run serve可以看到項目在瀏覽器中的title變成了我們設(shè)置的值title test,我們重新導(dǎo)出webpack的配置看看內(nèi)容是不是改變了

vue inspect > output.js

到此為止我們就通過修改webpack配置改變了項目title值。

chainWebpack

從上面的應(yīng)用實例中通過chainWebpack鏈式操作修改了webpack的配置,下面是幾個利用鏈式操作修改的例子

修改Loader選項

這是修改之前的配置

// vue.config.js
module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = '' // 修改的地方
          return options
        })
  }
}

修改后我們inspect結(jié)果

總結(jié):如果你想修改某個配置項的值我們都可以先使用inspect出webpack的配置內(nèi)容,對應(yīng)的每一項都有注釋告訴我們應(yīng)該如何書寫

例如上面使用紅框框出的

config.plugin('html')

以及

config.module.rule('vue').use('vue-loader')

添加Loader選項

module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = ''
          return options
        })
    // GraphQL Loader
    config.module
      .rule('graphql')
      .test(/\.graphql$/)
      .use('graphql-tag/loader')
        .loader('graphql-tag/loader')
        .end()
      // 你還可以再添加一個 loader
      .use('other-loader')
        .loader('other-loader')
        .end()
  }
}

替換規(guī)則的Loader

如果你要替換某個規(guī)則的Loader,如果直接調(diào)用鏈式操作,只是在該規(guī)則下增加了一條Loader

所以正確的做法是先把這個規(guī)則已有的Loader都給刪除,然后再加上自己的Loader,這里以svg為例,修改之前的內(nèi)容是

module.exports = {
  chainWebpack: config => {
    const svgRule = config.module.rule('svg')
    svgRule.uses.clear() // 清除已有的所有l(wèi)oader
    svgRule
      .use('vue-svg-loader')
        .loader('vue-svg-loader')
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = ''
          return options
        })
    // GraphQL Loader
    config.module
      .rule('graphql')
      .test(/\.graphql$/)
      .use('graphql-tag/loader')
        .loader('graphql-tag/loader')
        .end()
      // 你還可以再添加一個 loader
      .use('other-loader')
        .loader('other-loader')
        .end()
  }
}

此時我們inspect結(jié)果

添加plugin

const NodePolyfillPlugin = require('node-polyfill-webpack-plugin')

module.exports = {
  chainWebpack: config => {
    config
    	.plugin('node-polyfill-webpack-plugin')
    	.use(NodePolyfillPlugin)
  }
}

此時我們inspect結(jié)果

configureWebpack

// vue.config.js
module.exports = {
  configureWebpack: config => {
    console.log(config)
  },
  chainWebpack: config => {
    console.log(config)
  }
}

通過打印出來的值可以看到結(jié)果一樣,都是webpack的配置內(nèi)容。

configureWebpack對象返回的值會被webpack-merge合并到最終的webpack配置中,如果你需要基于環(huán)境有條件的配置行為,或者想要直接修改配置,可以使用這個。

該方法的第一個參數(shù)就是已經(jīng)解析好的配置,你可以直接修改配置,或者返回一個將會被合并的對象。

像這樣:

// vue.config.js
module.exports = {
  configureWebpack: config => {
	  if (process.env.NODE_ENV === 'production') {
	    // 為生產(chǎn)環(huán)境修改配置
	  } else {
	    // 為開發(fā)環(huán)境修改配置
	  }
	}
}

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中分割線的實現(xiàn)方式

    vue中分割線的實現(xiàn)方式

    這篇文章主要介紹了vue中分割線的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue3中的h函數(shù)及使用小結(jié)

    Vue3中的h函數(shù)及使用小結(jié)

    這篇文章主要介紹了Vue3中的h函數(shù)及使用小結(jié),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • Vue中使用JsonView來展示Json樹的實例代碼

    Vue中使用JsonView來展示Json樹的實例代碼

    這篇文章主要介紹了Vue之使用JsonView來展示Json樹的實例代碼,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • vue中css如何使用data中的變量

    vue中css如何使用data中的變量

    這篇文章主要介紹了vue中css如何使用data中的變量問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue-CLI 3 scp2自動部署項目至服務(wù)器的方法

    Vue-CLI 3 scp2自動部署項目至服務(wù)器的方法

    這篇文章主要介紹了Vue-CLI 3 scp2自動部署項目至服務(wù)器的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-07-07
  • Vue項目npm操作npm run serve或npm run dev報錯及二者的區(qū)別

    Vue項目npm操作npm run serve或npm run dev報錯及二者

    這篇文章主要介紹了Vue項目npm操作npm run serve或npm run dev報錯及二者的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue中調(diào)用HTTP請求的詳細步驟

    vue中調(diào)用HTTP請求的詳細步驟

    這篇文章主要介紹了vue中調(diào)用HTTP請求的詳細步驟,文中通過代碼示例給大家講解的非常詳細,對大家的學(xué)習或工作有一定幫助,需要的朋友可以參考下
    2024-07-07
  • 如何使用fetchEventSource實現(xiàn)sse流式請求

    如何使用fetchEventSource實現(xiàn)sse流式請求

    這篇文章主要介紹了如何使用fetchEventSource實現(xiàn)sse流式請求問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • VUE DEMO之模擬登錄個人中心頁面之間數(shù)據(jù)傳值實例

    VUE DEMO之模擬登錄個人中心頁面之間數(shù)據(jù)傳值實例

    今天小編就為大家分享一篇VUE DEMO之模擬登錄個人中心頁面之間數(shù)據(jù)傳值實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue項目中極驗驗證的使用代碼示例

    vue項目中極驗驗證的使用代碼示例

    這篇文章主要介紹了vue項目中極驗驗證的使用代碼示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2019-12-12

最新評論