首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当我导入固定字符串而不是文件时,在Webpack中是否可以运行我的自定义Loader?

当我导入固定字符串而不是文件时,在Webpack中是否可以运行我的自定义Loader?
EN

Stack Overflow用户
提问于 2021-07-31 21:06:13
回答 1查看 148关注 0票数 2

我正在尝试编写一个Webpack加载器,每当我导入一个特定的固定字符串"Hello“时,它都会在编译时运行我的加载器,并返回一个不可缓存的字符串。

代码语言:javascript
复制
import x from 'Hello';

console.log(x)

这里的问题是"Hello“不是一个文件。

为了做到这一点,我在module.rules的Webpack配置中引入了我的加载器,让我的加载器的test属性为"Hello“,但它不起作用。

代码语言:javascript
复制
// webpack.config.js
{
  ...
  module: { 
    rules: [
      {
        test: /Hello/,
        use: [
          {
            loader: path.resolve('./my-custom-loader.js'),
            options: {
              /* ... */
            },
          },
        ],
      },
      ...
    ],
    ...
  }
}

这在Webpack是不是可能的呢?

EN

回答 1

Stack Overflow用户

发布于 2021-07-31 23:16:46

//假设您的客户加载器位于加载器目录中

my-customer-loader.js

./loaders/my-customer-loader.js

//您的客户加载器my-customer-loader.js

代码语言:javascript
复制
module.exports = function(source){
    console.log(source)
    results = source + 'change source'
    return source
}

// webpack.config.js

代码语言:javascript
复制
{
    ....
    
    resolveLoader: {
        // webpack by default looks for loaders in node_modules so your must declare where you loader is located
        module: ['node_modules', path.resolve(__dirname, 'loaders')]
    },
    Module: {
        rules: [
            test: /\.js$/,
            use: 'my-customer-loader'
        ]
    }
    ......
}
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68605829

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档