最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • webpack入门(三)

    正文概述 掘金(小雯的老公)   2021-03-14   830

    loader

    loader是干什么用的呢?实际上,webpack在打包过程中,只能认识js和json文件,如遇到css和图片等类型的文件,他并不能识别,无法进行继续打包,会抛出错误。loader的作用就是让webpack去处理一些除了js和json文件类型以外的文件,并将它们转换为有效模块,以供应用程序使用,以及被添加到依赖图中

    在 webpack 的配置中,loader 有两个属性:

    test 属性,识别出哪些文件会被转换。 use 属性,定义出在进行转换时,应该使用哪个 loader。

    我们来看一个简单的loader使用例子:

    npm install raw-loader -D
    
    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          { 
            test: /\.txt$/,
            use: 'raw-loader'
          }
        ],
      },
    };
    

    loader的使用我们放在module属性下的rules中,module顾名思义就是模块的意思,这里我们处理的都是模块的内容,rules就是规则,他是一个数组,配置不同规则,可以处理不同的文件类型。

    loader处理样式

    假如我们现在有以下逻辑代码:

    import './index.css';
    
    let root = document.getElementById('root');
    root.classList.add('demo');
    

    现在我们要对上面这个js文件进行打包,很显然,打包的时候会报错,因为webpack打包的时候遇到css文件类型,他无法识别,我们也没告诉他,如果遇到css文件类型,应该如何处理,所以,我们在webpack.config.js中进行配置:

    npm install css-loader style-loader -D
    
    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          { 
            test: /\.txt$/,
            use: 'raw-loader'
          },
          {
            test: /\.css$/,
            use: [
              'style-loader',
              'css-loader'
            ]
          }
        ],
      },
    };
    

    进行了以上的配置之后,再进行打包,我们就会发现,打包成功了,我们经过配置,就是告诉了webpack,在打包的时候,如果遇到 .css 结尾的文件,就使用 style-loader , css-loader 这两个loader进行处理,那这两者在使用的时候有没有顺序呢,答案是:有的,webpack在处理的时候,是按照我们在use中配置的数组项中从下到上或者从右到左进行挨个处理的,这里,也就是先用css-loader处理,处理完后,再用style-loader处理。

    那么还有一个问题,为什么我们要使用style-loader呢?其实style-loader的作用是把css-loader处理好的css样式挂载到html文档中的head元素中的<style></style>元素中,这样,html的样式才能生效

    再来看下面这个css文件:

    // index.css
    
    @import './sub.css'
    
    
    // sub.css
    
    .demo{
      background-color: #eee;
    }
    

    我们在index.css文件中又使用import引入了另一个css文件,然后进行打包,浏览器打开html文件,样式上面没有问题,然后我们做如下的配置:

    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          { 
            test: /\.txt$/,
            use: 'raw-loader'
          },
          {
            test: /\.css$/,
            use: [
              'style-loader',
              {
                loader: 'css-loader',
                options: {
                  import: false
                }
              }
            ]
          }
        ],
      },
    };
    

    继续打包,浏览器打开html文件,发现,我们需要的样式不生效了。这里,我们可以发现,loader还可以通过options属性来配置我们需要的各项能力,这里的import属性,就是来启用/禁用 @import 解析的,我们设置成了false,css文件中的@import就无法解析了

    我们实际开发中也会用scss或者less文件来处理样式,那么scss文件我们改如何配置呢,下面也是一个简单处理scss文件的配置:

    npm install sass-loader node-sass -D
    

    我们需要使用上面两个包

    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          {
            test: /\.css$/,
            use: [
              'style-loader',
              {
                loader: 'css-loader',
                options: {
                  import: false
                }
              }
            ]
          },
          {
            test: /\.scss$/,
            use: [
              'style-loader',
              'css-loader',
              'sass-loader',
            ]
          }
        ],
      },
    };
    

    同样的,在use中的使用顺序是,先使用sass-loader将scss文件处理成css文件,再用css-loader处理css文件,最后使用style-loader将css文件内容挂到style元素中去

    接下来我们再介绍一个postcss-loader:

    npm install --save-dev postcss-loader postcss
    

    按照官方推荐,我们可以在与webpack.config.js同级目录下,新建一个postcss.config.js文件,这里我们也顺带介绍一下autoprefixer这个插件,可以先npm install autoprefixer -D来安装一下这个插件,然后我们在postcss.config.js中使用这个插件:

    // postcss.config.js
    module.export = {
      plugins: [
        require('autoprefixer')
      ]
    }
    
    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          {
            test: /\.css$/,
            use: [
              'style-loader',
              {
                loader: 'css-loader',
                options: {
                  import: false
                }
              }
            ]
          },
          {
            test: /\.scss$/,
            use: [
              'style-loader',
              {
                loader: 'css-loader',
                options: {
                  importLoaders: 2
                }
              }
              'sass-loader',
              'postcss-loader'
            ]
          }
        ],
      },
    };
    

    PostCSS 可以处理 CSS 的 loader,怎么处理呢?我们通过使用autoprefixer这个插件来举例,这个插件可以帮助我们在css属性前面自动加上-webkit-等浏览器属性。

    loader处理图片文件

    处理图片文件,我们需要使用file-loader

    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          {
            test: /\.(jpe?g|png|gif)$/,
            use: [
              {
                loader: 'file-loader',
                options: {
                  name: [name].[ext]  // [hash]
                }
              }
            ]
          }
        ],
      },
    };
    

    还有一个url-loader也可以处理图片文件

    module.exports = {
      entry: 'src/index.js',
      output: {
        filename: 'bundle.js',
        path: './dist'
      },
      module: {
        rules: [
          {
            test: /\.(jpe?g|png|gif)$/,
            use: [
              {
                loader: 'url-loader',
                options: {
                  limit: 20800
                }
              }
            ]
          }
        ],
      },
    };
    

    url-loader和file-loader的区别是什么呢?file-loader是直接将原图片打包至output的文件目录中,而url-loader则是直接将图片转化成base64直接放入在js文件中,但我们可以通过limit来配置,图片大小小于我们配置的limit,则会转化成base64,否则还是以图片打包到output的文件目录

    好了,这里我们就是简单介绍了loader的作用,大概知道了loader能干什么,至于更具体的每一个loader的使用方法和配置项,还是需要参考官方的文档,那里会更细更具体,在使用webpack过程中按需去查找即可


    起源地下载网 » webpack入门(三)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元