1. 每个单词的首字母大写

  • 要点:通过 text-transform 调正文字
  • 场景:每个单词的首字母大写,摆脱一味 JS 的控制
  • 兼容:all:text-transform
  • 代码:在线演示

2.使用input:checked单选高亮

  • 要点:通过 input:checked 单选高亮
  • 场景:单选高亮(之前做 pc 端的客户画像需求时,遇到需要左右两边等到的需求(左边块的高度会随着内容变化)),摆脱一味 JS 的控制
  • 兼容:text-transform
  • 代码:在线演示

3.使用vw定制rem自适应布局

  • 要点:移动端使用rem布局需要通过JS设置不同屏幕宽高比的font-size,结合vw单位和calc()可脱离JS的控制
  • 场景:rem页面布局(不兼容低版本移动端系统)
  • 兼容:vwcalc()

4.使用writing-mode排版竖文

  • 要点:通过writing-mode调整文本排版方向
  • 场景:竖行文字文言文诗词
  • 兼容:writing-mode
  • 代码:在线演示

5.使用text-align-last对齐两端文本

  • 要点:通过text-align-last:justify设置文本两端对齐
  • 场景:未知字数中文对齐
  • 兼容:text-align-last
  • 代码:在线演示

6.使用object-fit规定图像尺寸

  • 要点:通过object-fit使图像脱离background-size的约束,使用<img>来标记图像背景尺寸
  • 场景:图片尺寸自适应
  • 兼容:object-fit
  • 代码:在线演示

7.使用text-overflow控制文本溢出

8.使用letter-spacing排版倒序文本

  • 要点:通过letter-spacing设置负值字体间距将文本倒序
  • 场景:文言文诗词
  • 兼容:letter-spacing
  • 代码:在线演示

9.使用margin-left排版左重右轻列表

  • 要点:使用flexbox横向布局时,最后一个元素通过margin-left:auto实现向右对齐
  • 场景:右侧带图标的导航栏
  • 兼容:margin
  • 代码:在线演示

10.使用overflow-scrolling支持弹性滚动

  • 要点:iOS页面非 body 元素的滚动操作会非常卡( Android 不会出现此情况),通过 overflow-scrolling:touch 调用 Safari 原生滚动来支持弹性滚动,增加页面滚动的流畅度
  • 场景:iOS页面滚动
  • 兼容:iOS自带 -webkit-overflow-scrolling
    1
    2
    3
    4
    5
    6
    body {
    -webkit-overflow-scrolling: touch;
    }
    .elem {
    overflow: auto;
    }

11.使用transform启动GPU硬件加速

  • 要点:有时执行动画可能会导致页面卡顿,可在特定元素中使用硬件加速来避免这个问题
  • 场景:动画元素(绝对定位、同级中超过6个以上使用动画)
  • 兼容:transform
    1
    2
    3
    .element {
    transform: translate3d(0, 0, 0); /* translateZ(0)亦可 */
    }

12.使用pointer-events禁用事件触发

  • 要点:通过pointer-events:none禁用事件触发(默认事件、冒泡事件、鼠标事件、键盘事件等),相当于<button>disabled
  • 场景:限时点击按钮(发送验证码倒计时)、事件冒泡禁用(多个元素重叠且自带事件、a标签跳转)
  • 兼容:pointer-events
  • 代码:在线演示

13.使用:valid和:invalid校验表单

  • 要点:<input>使用伪类:valid:invalid配合pattern校验表单输入的内容
  • 场景:表单校验
  • 兼容:pattern:valid:invalid
  • 代码:在线演示

14.使用:focus-within分发冒泡响应

15.使用color改变边框颜色

  • 要点:border没有定义border-color时,设置color后,border-color会被定义成color
  • 场景:边框颜色与文字颜色相同
  • 兼容:color
    1
    2
    3
    4
    .elem {
    border: 1px solid;
    color: #f66;
    }

16.使用filter开启悼念模式

  • 要点:通过filter:grayscale()设置灰度模式来悼念某位去世的仁兄或悼念因灾难而去世的人们
  • 场景:网站悼念
  • 兼容:filter
1
2
3
html {
filter: grayscale(100%);
}

17.使用::selection改变文本选择颜色

  • 要点:通过::selection根据主题颜色自定义文本选择颜色
  • 场景:主题化
  • 兼容:::selection
  • 代码:在线演示

18.使用linear-gradient控制文本渐变

19.使用transform模拟视差滚动

20.使用linear-gradient控制背景渐变

  • 要点:通过linear-gradient设置背景渐变色并放大背景尺寸,添加背景移动效果
  • 场景:主题化彩虹背景墙
  • 兼容:gradientanimation
  • 代码:在线演示

21.使用animation-delay保留动画起始帧

  • 要点:通过transform-delayanimation-delay设置负值时延保留动画起始帧,让动画进入页面不用等待即可运行
  • 场景:开场动画
  • 兼容:transformanimation
  • 代码:在线演示

22.使用caret-color改变光标颜色

  • 要点:通过caret-color根据主题颜色自定义光标颜色
  • 场景:主题化
  • 兼容:caret-color
  • 代码:在线演示

23.使用box-shadow裁剪图像

  • 要点:通过box-shadow模拟蒙层实现中间镂空
  • 场景:图片裁剪新手引导背景镂空投射定位
  • 兼容:box-shadow
  • 代码:在线演示

24.滚动指示器

25.换色器

  • 要点:通过拾色器改变图像色相的换色器
  • 场景:图片色彩变换
  • 兼容:mix-blend-mode
  • 代码:在线演示

26.倒影加载条

27.动态边框

  • 要点:鼠标悬浮时动态渐变显示的边框
  • 场景:悬浮按钮边框动画
  • 兼容:gradient
  • 代码:在线演示

28.立体按钮

29.自适应相册