在webpack中使用postcss之插件cssnext
学习了precss插件包在webpack中的用法后,下面介绍postcss的另一个重要插件cssnext,步骤没有precss用法详细,主要介绍css4的语法,cssnext目前支持了部分新特性,你可以在css4-selectors.com网站上测试你的浏览器是否支持这些css4选择器。
cssnext能让未来的css语法在今天的浏览器中工作,fallbacks能让今天的css语法在以前的浏览器上工作。
一、安装postcss插件cssnext
cnpm i -D cssnext
:root {
--lh: 30px;
--we: #fff;
--ora: #FFA500;
--bg-font: {
background: #00BBFE;
color: var(--we);
}
}
1、变量
/* before */
.vars-1 {
line-height: var(--lh);
color: var(--we);
background-color: #CA1F2D;
}
/* after */
.vars-1 {
line-height: 30px;
color: #fff;
background-color: #CA1F2D;
}
2、嵌套
/* before */
.nested {
background: #00BD00;
& p {
display: inline-block;
color: white;
}
/* @nest rule (for complex nesting) */
@nest span & {
color: blue;
}
/* media query automatic nesting */
@media (min-width: 500px) {
color: yellow;
}
}
/* after */
.nested {
background: #00BD00;
}
.nested p {
display: inline-block;
color: white;
}
.nested {
/* @nest rule (for complex nesting) */
}
span .nested {
color: blue;
}
.nested {
/* media query automatic nesting */
}
@media (min-width: 500px) {
.nested {
color: yellow;
}
}
3、继承
/* before */
.extended {
@apply --bg-font;
}
/* after */
.extended {
background: #00BBFE;
color: #fff;
}
4、calc()函数
.tcalc{
background-image: url(dog.png);
background-position: calc(100% - 50px) calc(100% - 20px);
}
5、color()函数
/* before */
a {
color: color(red alpha(-10%));
}
a:hover {
color: color(red blackness(80%));
}
/* after */
a {
color: rgba(255, 0, 0, 0.9);
}
a:hover {
color: rgb(51, 0, 0);
}
Webkit内核"safari6"和"chrome21"支持css4的background-image新规范草案image-set。通过Webkit内核的浏览器私有属性"-webkit",image-set为Web前端人员提供了一种解决高分辨率图像的显示,用来解决苹果公司提出的Retian屏幕显示图片的技术问题。
在cssnext出来之前,可以这样做,来解决兼容性问题。
.logo-icon {
background-image: url(dog.png);
background: image-set(url(dog.png) 1x,url(dog.png) 2x) center;
}
不像Media Queries,image-set不需要告诉浏览器使用什么图像,而是直接提供了图像让浏览器选择。
- 如果浏览器不支持image-set,则启用background-image;
- 如果浏览器支持image-set,浏览器会选择image-set中的@1x背景图像;
- 如果浏览器支持image-set,而且是在retina屏幕下,浏览器会选择image-set中的@2x背景图像。
postcss插件cssnext出来后,可以放心用image-set,cssnext会自动处理未来的新语法。
/* before */
.imgset {
background-image: image-set(url(img/dog.png) 1x,
url(img/tiger.png) 2x,
url(img/lien.png) 600dpi);
}
/* after */
.imgset{
background-image: url(img/dog.png);
}
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi){
.imgset{
background-image: url(img/tiger.png);
}
}
@media (-webkit-min-device-pixel-ratio: 6.25), (min-resolution: 600dpi){
.imgset{
background-image: url(img/lien.png);
}
}
7、一些伪类
/* before */
div:not(.not-1, .not-2) {
text-align: center;
}
/* after */
div:not(.not-1):not(.not-2) {
text-align: center;
}
/* before */
.mymixin{
background-color:blue;
}
.mymixin:matches(:hover, .helper) {
background-color:#00BBFE;
& a {
color: #fff;
}
}
/* after */
.mymixin{
background-color:blue;
}
.mymixin:hover, .mymixin.helper {
background-color:#00BBFE;
}
.mymixin:hover a, .mymixin.helper a {
color: #fff;
}
8、一些选择器
/* before */
.shape {
float: left;
width: 300px;
shape-outside: circle(50%);
}
/* after */
.shape {
float: left;
width: 300px;
-webkit-shape-outside: circle(50%);
shape-outside: circle(50%);
}
shape选择器可将文字排列在非矩形对象周围,比如曲线。
三、cssnext还未支持的css4新特性
1、一些伪类
a:has( > span ) {
border: 1px solid #000;
}
li:not(:has(p)) {
padding-bottom: 1em;
}
2、混合
background-blend-mode: hue | multiply; mix-blend-mode: screen;
目前浏览器还不支持,可以先在photoshop中混合图片。
3、一些选择器
.main {
position:relative;
}
.exclusion {
position: absolute;
top: 14em;
left: 14em;
width: 320px;
wrap-flow: both;
}
exclusion选择器使文字环绕在定位矩形对象的四周。
在webpack中使用postcss之插件cssnext的更多相关文章
- 在webpack中使用postcss之插件包precss
precss是一个预处理css的插件包,集成了很多postcss插件的功能,比如嵌套,变量,继承,混合,循环,判断.下面来介绍如何在webpack中使用precss.一.新建项目1.新建package ...
- webpack中插件 prerender-spa-plugin 来进行SEO优化(二十四)
vue.react对于开发单页应用来说带来了很好的用户的体验,但是同样有缺点,比如首页加载慢,白屏或SEO等问题的产生.为什么会出现这种情况呢?我们之前开发单页应用是这样开发的,比如首页 index. ...
- 深入浅出的webpack构建工具---PostCss(五)
一:PostCss是什么? PostCss是一个样式处理工具,它通过自定义的插件和工具生态体系来重新定义css.它鼓励开发者使用规范的css原生语法编写代码,然后配置编译器转换需要兼容的浏览器版本, ...
- webpack中clean-webpack-plugin插件使用遇到的问题及解决方法
webpack 会生成文件,然后将这些文件放置在 /dist 文件夹中,但是 webpack 无法追踪到哪些文件是实际在项目中用到的. 通常,在每次构建前清理 /dist 文件夹,是比较推荐的做法,因 ...
- [翻译]在gulp构建工具中使用PostCSS
前言 PostCSS已经在一段时间内迅速普及,如果你还不知道PostCSS或还没有使用它,我建议你看一下之前的一篇介绍文章<PostCSS简介>,其中介绍了使用PostCSS的基本方法,包 ...
- PostCSS的插件 -- 关于vue rem适配布局方案
PostCSS的插件 作用:用于自动将像素单元生成rem单位 记以下三种 postcss-plugin-px2rem postcss-pxtorem postcss-px2rem 任选一种,最近大家推 ...
- Webpack中hash与chunkhash的区别,以及js与css的hash指纹解耦方案
文件的hash指纹通常作为前端静态资源实现增量更新的方案之一,Webpack是目前最流行的开源编译工具之一,其强大的功能也带来很多坑(当然,大部分麻烦其实都可以在官方文档中找到答案). 比如,在Web ...
- 【原】react中如何使用jquery插件
react的思想是虚拟dom,提倡最好较少dom的操作,可是我们在写网页的时候,有些复杂的交互还是离不开jquery插件的.而且当你把jquery直接拿来用的时候,你会发觉会报错,要么是找不到那个插件 ...
- 在webpack里使用jquery.mCustomScrollbar插件
malihu-custom-scrollbar-plugin是一个依赖jquery的自定义网页滚动条样式插件 网站:http://manos.malihu.gr/jquery-custom-conte ...
随机推荐
- 同步sync 异步async
线程中 同步任务是串行队列,也就是按顺序执行. 同步任务:不会开辟新的线程,它是在当前线程执行的. dispatch 调度 GCD里面的函数都是以dispatch开头的. 同步任务 步骤: 1. ...
- canny 算子python实现
1. Canny介绍 Canny算子与Marr(LoG)边缘检测方法类似,也属于是先平滑后求导数的方法.John Canny研究了最优边缘检测方法所需的特性,给出了评价边缘检测性能优劣的三个指标: 1 ...
- mysql系列一、mysql数据库规范
一. 表设计 库名.表名.字段名必须使用小写字母,“_”分割. 库名.表名.字段名必须不超过12个字符. 库名.表名.字段名见名知意,建议使用名词而不是动词. 表必须使用InnoDB存储引擎. 表必须 ...
- saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy
saltstack自动化运维系列⑥SaltStack实践安装配置HAproxy 下载haproxy1.6.2.tar.gz下载地址:http://www.haproxy.org/download/1. ...
- pytest七:assert断言
断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了.什么是断言呢?简单来讲就是实际结果和期望结果去对比,符合预期那就测试 pass,不符合预期那就测试 failed py ...
- js字符串转换成数字与数字转换成字符串的实现方法
转载:点击查看地址 js字符串转换成数字 将字符串转换成数字,得用到parseInt函数.parseInt(string) : 函数从string的开始解析,返回一个整数. 举例:parseInt(' ...
- python 全栈开发,Day95(RESTful API介绍,基于Django实现RESTful API,DRF 序列化)
昨日内容回顾 1. rest framework serializer(序列化)的简单使用 QuerySet([ obj, obj, obj]) --> JSON格式数据 0. 安装和导入: p ...
- python 全栈开发,Day84(django请求生命周期,FBV和CBV,ORM拾遗,Git)
一.django 请求生命周期 流程图: 1. 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者post, ...
- Windows安装Nginx
环境:Windows 10 Nginx :nginx-1.13.12 安装步骤: 1.下载Nginx 进入官方网站下载页面 https://nginx.org/en/download.html 可以看 ...
- maven创建父子关系的聚合项目
我最近使用eclipse的mavean插件创建父子关系的聚合项目,如果创建子工程直接在父工程我相信大家都会创建,但是子工程在父工程中的其中一个文件夹里面,我们创建子工程是直接存在父工程下面的,当我们想 ...