CSS开发技巧(值得收藏)

作者: littleyu | 来源:发表于2020-01-09 16:24 被阅读0次

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
body {
    -webkit-overflow-scrolling: touch;
}
.elem {
    overflow: auto;
}

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

  • 要点:有时执行动画可能会导致页面卡顿,可在特定元素中使用硬件加速来避免这个问题
  • 场景:动画元素(绝对定位、同级中超过6个以上使用动画)
  • 兼容:transform
.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
.elem {
    border: 1px solid;
    color: #f66;
}

16.使用filter开启悼念模式

  • 要点:通过filter:grayscale()设置灰度模式来悼念某位去世的仁兄或悼念因灾难而去世的人们
  • 场景:网站悼念
  • 兼容:filter
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.自适应相册

原文

相关文章

  • CSS开发技巧(值得收藏)

    1. 每个单词的首字母大写 要点:通过 text-transform 调正文字 场景:每个单词的首字母大写,摆脱一...

  • 值得收藏的CSS小技巧

    在工作中,为了提升工作效率与持续学习,常常会收集整理很多素材,有网站案例源码,有片段的代码特,在这里我收集的一些C...

  • CSS教程汇总

    CSS揭秘实用技巧总结 不止于 CSS 灵活运用CSS开发技巧 前端基础篇之CSS世界 你未必知道的49个CSS知...

  • 45个值得收藏的 CSS 形状

    摘要: CSS炫技。 原文:45个值得收藏的 CSS 形状 作者:前端小智 Fundebug经授权转载,版权归原作...

  • CSS开发技巧

    让图片自适应容器(div)大小 img {width: 100%;height: 100%;max-width: ...

  • 2016/12/22

    技术 daneden/animate.css 10个值得前端收藏的CSS3动效库(工具) 图解SQL的各种连接jo...

  • CSS 常用效果整理

    整理场景的css 灵活运用CSS开发技巧 1、使用 text-align-last 对齐两端文本代码 ...

  • 《HTML与CSS知识》系列分享专栏

    收藏HTML和CSS方面的技术文章,作为一个WEB开发者,必须要知道HTML和CSS方面的知识,即使作为后台开发者...

  • 每日推荐文章

    1、css-tricks css-tricks是一个关于运用CSS技术进行网络开发和设计的小技巧的交流网站。你可以...

  • 收藏!Web前端开发技巧:CSS开发中的十不要

    Web前端开发中的CSS开发中的十不要: 1.不要滥用类 在有意义的地方使用ID而不要使用类。这是一个使得浏览器能...

网友评论

    本文标题:CSS开发技巧(值得收藏)

    本文链接:https://www.haomeiwen.com/subject/podnectx.html