资讯专栏INFORMATION COLUMN

你不知道的CSS(三)

xiangzhihong / 695人阅读

摘要:本文首发于我的博客在前面两篇文章你不知道的一和你不知道的二中大致介绍了一些方面比较隐晦的但又很实用的技巧。系列文章你不知道的一你不知道的二本文首发于我的博客

本文首发于我的博客

在前面两篇文章《你不知道的CSS(一)》和《你不知道的CSS(二)》中大致介绍了一些CSS方面比较隐晦的但又很实用的技巧。相信这些技巧会为大家在项目实践中带来一定的帮助,本文作为《你不知道的CSS》系列的第三篇文章,将继续在CSS技巧方面进行探讨,不同于前两篇的是,本文将着重介绍CSS中伪类和伪元素在项目中的应用场景。伪类相信大家最熟悉也是用的最多的莫过于:hover, :active, :focus之类的,因为这些在平常的项目中太常用了(然而我目前依然见过还有用js去添加.hover类来变化背景色的同学?)。而伪元素如:before, :after相信大家也用的烂熟了。 当然对于比较常见的伪类(元素)不在本文的讨论范围类,本文主要介绍一些生僻的但是又非常实用的伪类(元素)。

CSS的世界已经变天了,抛开过去,拥抱变化吧~

伪类和伪元素的区别

伪类和伪元素是一个比较容易混淆的概念,这不仅仅是从名称上,而且在写法上也是相似的(目前因为兼容性的问题,它们的写法是一致的)。这就更容易混淆了?。但还是希望大家在书写的过程中养成习惯,至于兼容性交给postcss等转换工具去实现。

规范

css3 明确规定了伪类用一个冒号:来表示,而伪元素则用两个冒号::来表示。

区别

伪类更多的定义的是状态,如:hover,或者说是一个可以使用CSS进行修饰的特定的特殊元素,如:first-child

伪类使用一个冒号:

常见伪类:

:hover

:active

:focus

:visited

:link

:lang

:first-child

:last-child

:not

伪元素简单来说就是不存在于DOM文档树中的虚拟的元素,它们和HTML元素一样,但是你又无法使用JavaScript去获取,如:before

伪元素使用两个冒号::

常见伪元素:

::before

::after

::first-letter

::first-line

:valid:invalid来做表单即时校验

html5丰富了表单元素,提供了类似required,email,tel等表单元素属性。同样的,我们可以利用:valid:invalid来做针对html5表单属性的校验。

:required 伪类指定具有required 属性的表单元素

:valid 伪类指定一个通过匹配正确的所要求的表单元素

:invalid 伪类指定一个不匹配指定要求的表单元素

有没有最开始学angular的感觉?,快点直戳demo感受下吧

.valid {
  border-color: #429032;
  box-shadow: inset 5px 0 0 #429032;
}
.invalid {
  border-color: #D61D1D;
  box-shadow: inset 5px 0 0 #D61D1D;
}
.required {
  border-color: #056B9B;
  box-shadow: inset 5px 0 0 #056B9B;
}
input,
textarea {
  &:valid {
    @extend .valid;
  }
  &:invalid {
    @extend .invalid;
  } 
  &:required {
    @extend .required;
  }
}
:target来实现折叠面板

:target是文档的内部链接,即 URL 后面跟有锚名称 #,指向文档内某个具体的元素。

利用 :target 的特性可以实现以前只能使用JavaScript实现的显示隐藏或者Collapse 折叠面板。

.collapse {
  >.collapse-body {
    display: none;
    &:target {
      display: block;
    }
  }
}


预览CSS实现Collapse折叠面板demo

:not来排除其他选择器

:not表示的是一个非/不是的概念。我在项目mo-css上用到过很多次,尤其是在表单类中,我用它来设置表单元素在readonlydisabled状态之外的hover等状态,以便于当元素在readonlydisabled时,元素不具有hover状态。

@mixin buttonStyle ($border, $background, $color, $hoverBorder, $hoverBackground, $hoverColor) {
    color: $color;
    border-color: $border;
    background-color: $background;
    &:not(.readonly):not([readonly]):not(.disabled):not([disabled]) {
        &:hover,
        &:active {
            color: $hoverColor;
            border-color: $hoverBorder;
            background-color: $hoverBackground;
        }
    }
}
:nth-child(even/odd)来实现隔行变色

:nth-child等伪类的参数大多是一个数值或者数学表达式2n+1,而even作为参数用来表示偶数odd作为参数用来表示奇数的类似于别骂的特性往往被忽略。

ul {
  &.odd {
    >li:nth-child(odd) {
      background: red;
    }
  }
  &.even {
    >li:nth-child(even) {
      background: green;
    }
  }
}

::selection来美化选中文本

就像你用鼠标选中这段话看到的那样,::selection用来设置选中文本的样式,从而改变浏览器一成不变的文本选中色(蓝色)。

::selection{
 color: #fff;
 background-color: #6bc30d;
}

::placeholder来美化占位符

::placeholder用来修饰input/textarea等表单元素placeholder属性的样式。

@mixin placeholder {
  &::-webkit-input-placeholder {
    @content
  }
  &::-moz-placeholder {
    @content
  }
  &:-ms-input-placeholder {
    @content
  }
}
input, textarea {
   @include placeholder {
      color: #f00;
   }
}
//css
input::-webkit-input-placeholder{
    color: #f00;
}
input::-moz-placeholder{
     color: #f00;
}
input:-ms-input-placeholder{
     color: #f00;
}
::first-letter来实现段落首字下沉

首字下沉 : 设置段落的第一行第一字字体变大,并且向下一定的距离,与后面的段落对齐,段落的其它部分保持原样

就像图中展示的那样,之前实现类似效果,我们需要多加一个标签,如:

...

然而,现在只需要一个CSS伪元素就可以实现。

first-letter 伪元素用于向文本的首字母设置特殊样式

p::first-letter{
  font-size: 6em;
  line-height: 1;
  float: left;
}
::first-line来特殊标记段落第一行

就如它的名字一样,这个伪元素代表了段落的第一行,你可以使用任意样式来控制它。

p::first-line{
  color: red
}
小结

CSS的伪类和伪元素还有很多,因为或兼容性或其他原因,文章中介绍的几种伪类/元素用的比较少,这不得不说是一种遗憾。但,为了保证项目的健康和可持续化,一定要注意伪类和伪元素的区别,尽可能的在写伪类的时候使用一个冒号:,而在写伪元素的时候用两个冒号::,就像使用autoprefixer来生成浏览器前缀一样,将:::的转换交给postcss等工具去做。

系列文章

你不知道的CSS(一)

你不知道的CSS(二)

本文首发于我的博客

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/112623.html

相关文章

  • 你不知道Virtual DOM(二):Virtual Dom更新

    摘要:变化的只有种更新和删除。页面的元素的数量随着而变。四总结本文详细介绍如何实现一个简单的算法,再根据计算出的差异去更新真实的。 欢迎关注我的公众号睿Talk,获取我最新的文章:showImg(https://segmentfault.com/img/bVbmYjo); 一、前言 目前最流行的两大前端框架,React 和 Vue,都不约而同的借助 Virtual DOM 技术提高页面的渲染...

    testbird 评论0 收藏0
  • 你不知道width:auto

    摘要:比方说,这些元素的宽度默认是与父级容器的。典型代表就是浮动绝对定位元素或者元素,英文称为,收缩到合适中的指的就是这种宽度表现收缩到最小。     说到widh:auto这个属性大家一定不陌生,也都知道width的默认值是auto,正因为auto是默认值,极少有人去关注auto的宽度表现,下面就让我介绍一下我认识的auto的四种宽度表现 1.充分利用可用空间。比方说,、这些元素的宽度默认...

    DandJ 评论0 收藏0
  • 你不知道浏览器页面渲染机制

    摘要:前言浏览器的内核是指支持浏览器运行的最核心的程序,分为两个部分的,一是渲染引擎,另一个是引擎。渲染引擎在不同的浏览器中也不是都相同的。接下来就是浏览器的渲染过程。布局完成后,浏览器会立即发出和事件,将渲染树转换成屏幕上的像素。 前言 浏览器的内核是指支持浏览器运行的最核心的程序,分为两个部分的,一是渲染引擎,另一个是JS引擎。渲染引擎在不同的浏览器中也不是都相同的。目前市面上常见的浏览...

    zhunjiee 评论0 收藏0
  • 你不知道浏览器页面渲染机制

    摘要:前言浏览器的内核是指支持浏览器运行的最核心的程序,分为两个部分的,一是渲染引擎,另一个是引擎。渲染引擎在不同的浏览器中也不是都相同的。接下来就是浏览器的渲染过程。布局完成后,浏览器会立即发出和事件,将渲染树转换成屏幕上的像素。 前言 浏览器的内核是指支持浏览器运行的最核心的程序,分为两个部分的,一是渲染引擎,另一个是JS引擎。渲染引擎在不同的浏览器中也不是都相同的。目前市面上常见的浏览...

    aboutU 评论0 收藏0
  • 【译】一些你不知道CSS属性

    摘要:目前,和不支持该属性,但不久后就会改变。承诺支持该属性,值得期待等支持该属性。在知乎的一个专栏上介绍了三个奇淫技巧,很有用,补充在此文后面关于几乎没人知道的件事英文原文译文出处一些你不知道的属性 Box-sizing 尽管box-sizing在CSS3中才被引入,其有一个值是border-box,让元素的高和宽包含了填充和边框。 .div { width: 150px; ...

    U2FsdGVkX1x 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<