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开发技巧(值得收藏)

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