Configure loader in vue-cli3 vue.config.js

Front-end rookie asks for help: it seems feasible to introduce jquery, globally into the vue project and find a document. To use expose-loader,
https://www.cnblogs.com/qiqi1.
, but the configuration is not quite the same as vue.config.js.
also found that the loader in vue.config.js is like this

.
             // vue.config.js
             module.exports = {
              chainWebpack: config => {
               config.module
                .rule("scss")
                .use("sass-loader")
                .tap(options =>
                 merge(options, {
                  includePaths: [path.resolve(dirname, "node_modules")],
                 })
                )
              }
             

but what I want to configure now is expose-loader, how to change it? thank you, boss.

Sep.16,2021

blogger, found a better solution. Instead of using webpack-chain, he used the simple webpack configuration interface provided by vue-cli: configureWebpack , which is also solved. It feels a little simpler and easier to understand.

configureWebpack: (config) => {
    config.module.rules.push({
      // jquery
      test: require.resolve('jquery'),
      use: [{
        loader: 'expose-loader',
        options: 'jquery'
      }, {
        loader: 'expose-loader',
        options: '$'
      }, {
        loader: 'expose-loader',
        options: 'jQuery'
      }]
    })
  }

    
 
    config.module
        .rule('expose1')
        .test(require.resolve('jquery'))
            .use()
            .loader('expose-loader')
            .options("jQuery")
            .end()
    config.module
        .rule('expose2')
        .test(require.resolve('jquery'))
            .use()
            .loader('expose-loader')
            .options("$")
            .end()

 module: {
    rules: [
      {test: require.resolve("jquery"), use: "expose-loader?$"},
      {test: require.resolve("jquery"), use: "expose-loader?jQuery"},
    ]
}
// 

you can refer to an article I wrote earlier:
citing jQuery and bootstrap in vue-cli scaffolding and writing css using sass and less [introduction to vue-cli configuration]: https://juejin.im/post/5986f5.

Menu