Webpack入门,样式预处理

样式预处理指的是开发者在开发过程中经常会使用一些样式预编译语言,如SCSS、Less等,在项目打包过程中再将这些预编译语言转换成CSS。借助这些语言强大和便捷的特性,可以降低项目的开发和维护成本。

Sass与SCSS

Sass本身是对CSS的语法增强,它有两种语法,现在使用更多的是SCSS(对CSS 3的扩充版本)。

sass-loader就是将SCSS语法编译为CSS,因此在使用时通常还要搭配css-loader和style-loader。loader本身只是编译核心库与Webpack的连接器,因此在项目工程中除了sass-loader以外还要安装sass,sass是真正用来编译scss的,而sass-loader只是起到粘合的作用。

安装命令如下:

npm install sass-loader sass -D

接着在Webpack配置中添加处理SCSS文件规则。

// webpack.config.js
module.exports = {
  ...
  module: {
    rules: [{
      test: /\.scss$/,
      use: ['style-loader','css-loader','sass-loader']
    }]
  }
}

之后就可以在项目工程中新建scss文件,使用scss语法了。

温馨提示

如果想在浏览器的调试工具里查看源码,需要分别为sass-loader和css-loader单独添加source-map的配置项。

Less同样是对CSS的一种扩展。与SCSS类似,它也需要安装loader和其本身的编译模块。安装命令如下:

npm install less-loader less -D

Less在配置上也与SCSS十分类似。

// webpack.config.js
module.exports = {
  ...
  module: {
    rules: [{
      test: /\.less$/,
      use: ['style-loader','css-loader','less-loader'],
    }]
  }
}

PostCSS

严格来说,PostCSS并不能算是一个CSS的与编译器,它只是一个编译插件的容器。它的工作模式是接收样式源代码并交由编译插件处理,最后输出CSS文件。开发者可以自己指定使用哪些插件来实现特定的功能。

使用post-loader可以轻松地将PostCSS与Webpack连接起来。安装命令如下:

npm install post-loader postcss -D
// webpack.config.js
module.exports = {
  ...
  module: {
    rules: [{
      test: /\.css$/,
      use: ['style-loader','css-loader','postcss-loader'],
    }]
  }
}

温馨提示

postcss-loader可以与css-loader结合使用,也可以单独使用,也就是说不配置css-loader也可以达到相同的效果。唯一不同的是,单独使用postcss-loader时不建议使用CSS中的@import语句,否则会产生冗余的代码,因此官方推荐将postcss-loader放在css-loader之后使用。

除此之外,PostCSS要求必须有一个单独的配置文件,因此需要在项目的根目录下创建一个postcss.config.js文件。

PostCSS一个最广泛的应用场景就是与Autoprefixer结合,为CSS自动添加厂商前缀。Autoprefixer是一个样式工具,可以根据caniuse.con上的数据,自动决定是否要为某一特性添加厂商前缀,并且可以由开发者为其指定支持浏览器的范围。

安装命令如下:

npm install autoprefixer -D

在postcss.config.js中添加autoprefixer。

// postcss.config.js
module.exports = {
  plugin: [
    autoprefixer({
      grid: true,
      browsers: [
        '>1%',
        'last 3 versions',
        'android 4.2',
        'ie 8'
      ]
    })
  ]
}

开发者可以在autoprefixer中添加需要支持的特性(如grid)以及兼容哪些浏览器。配置好之后,开发者就可以使用一些较新的CSS特性。

.container {
  display: grid;
}

// 由于在上面的配置中指定了grid:true,也就是为grid特性添加IE前缀,经过编译后则会成为

.container {
  display: -ms-grid;
  display: grid;
}

stylelint

stylelint是一个CSS的质量检测工具,就像eslint一样,开发者可以为其添加各种规则,来统一项目的代码风格,确保代码质量。

安装命令如下:

npm install stylelint -D

在postcss.config.js中添加相应配置。

// postcss.config.js
const stylelint = require("stylelint");
module.exports = {
  plugin: [
    stylelint({
      config: {
        rules: {
          'declaration-no-important': true,
        }
      }
    })
  ]
}

上面的配置添加了declaration-no-important这样一条规则,即当代码中出现“!important”时就会给出警告。

CSSNext

PostCSS可以与CSSNext结合使用,让开发者在应用中使用最新的CSS语法特性。

安装命令如下:

npm install postcss-cssnext -D

在postcss.config.js中添加相应配置。

// postcss.config.js
const postcssCssnext = require('postcss-cssnext');
module.exports = {
  plugins: [
    postcssCssnext({
      browsers:[
       '>1%',
       'last 2 versions',
      ]
    })
  ]
}

制定好需要支持的浏览器之后,开发者就可以顺畅地使用CSSNext的特性了。PostCSS会帮助开发者把CSSNext的语法翻译为浏览器能接收的属性和形式。

:root {
  --highlightColor: hwb(190,35%,20%);
}
body {
  color: var(--highlightColor);
}

// 打包后的结果

body{
  color: rgb(89,185,204);
}

原创文章,作者:ZERO,如若转载,请注明出处:https://www.edu24.cn/course/webpack-style-preprocessing.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
上一篇 2022年11月24日
下一篇 2022年11月28日

相关推荐

  • 初识Spring Boot

    什么是Spring Boot Spring Boot是由Pivotal Software公司于2013年研发的全新Java开发框架。其设计目的是用来简化新Spring应用的初始搭建…

    2024年6月16日
    406
  • Vue项目中实现用户登录及token验证

    在前后端完全分离的情况下,Vue项目中实现token验证大致思路如下: 第一次登录的时候,前端调后端的登陆接口,发送用户名和密码 。 后端收到请求,验证用户名和密码,验证成功,就给…

    2019年8月8日
    5.0K
  • Java自学之抽象类与接口

    面向对象程序设计中,类继承的主要作用的扩充已有类的功能。子类可以根据自己的需要选择是否要覆写父类中的方法,所以一个设计完善的父类是无法对子类做出任何强制性的覆写约定。为了解决这样的…

    2020年12月7日
    1.2K
  • Java自学之多线程编程

    多线程编程是Java语言最为重要的特性之一。利用多线程技术可以提升单位时间内的程序处理性能,也是现代程序开发中高并发的主要设计模式。 进程与线程 进程是一个应用程序。线程是一个进程…

    2020年12月16日
    1.5K
  • Java自学之类结构扩展

    面向对象中的核心组成是类与接口,在项目中会利用【包】进行一组相关类的管理,这样适合于程序代码的部分更新,也更加符合面向对象封装性的概念,同时合理地使用封装也可以方便地实现实例化对象…

    2020年12月10日
    1.3K
  • Webpack入门,常用loader

    babel-loader babel-loader用于处理ES6+并将其编译为ES5,它使开发者能够在工程中使用最新的语言特性,同时不必特别关注这些特性在不同平台的兼容问题。 在安…

    2022年11月23日
    617
  • MySQL数据库入门知识点整理

    数据库基本操作 1、创建数据库语句 数据库名称有以下几点要求 不能与已存在的数据库名称相同; 由字母、数字、下划线、@、$和#符号组成; 不能以数字及$符号开头; 标识符不能使用M…

    2020年7月7日
    1.5K
  • css如何利用transparent属性设置透明度?transparent属性绘制各种三角形

    想到用css设置元素透明度,大家的第一反应会是:用Opacity属性来设置透明度,其实在css中还有其他设置透明度的方法。本章给大家介绍用transparent属性设置透明度,以及…

    2021年2月25日
    1.3K
  • JavaWeb入门案例之用户注册

    前言 之前把Java的基础知识系统的过了一遍,目前总算可以看懂Java代码了,接下来就是要学习Java开发框架(主要是springMVC)。 下面用一个用户注册的小案例,来总结一下…

    2021年1月13日
    1.6K
  • 封装JDBC工具类,连接MySQL数据库

    JDBC是由java编程语言编写的类及接口组成,同时它为程序开发人员提供了一组用于实现对数据库访问的JDBC API,并支持SQL语言。利用JDBC可以将JAVA代码连接到orac…

    2022年3月31日
    837