11个CSS常用技巧梳理

前言

在日常前端开发中,CSS 往往被认为只是“样式美化”的工具,但其实它远比我们想象中强大。掌握一些 CSS 的实用小技巧,不仅可以大幅提升开发效率,还能写出更优雅、可维护的代码。

本文将整理一系列 CSS 中常被忽视但极具价值的小技巧,帮助你在页面布局、响应式设计和用户体验上更进一步。

1、图片文字环绕

shape-outside 是一个允许设置形状的 CSS 属性。它还有助于定义文本流动的区域

.any-shape {
width: 300px;
float: left;
shape-outside: circle(50%);
}

圆形:shape-outside: circle(50%);  //第一个值代表半径
椭圆:shape-outside: ellipse(60px80px);  //第一个值代表半径;第二个值代表半径
多边形:
shape-outside: polygon(00,100%100%,0100%);(三角形)
shape-outside: polygon(100px0,200px60px,200px120px,100px200px,0120px,060px);(六边形)

//最少3个值,也就是说,至少要3个点组成一个三角形,每个点有x,y方向移动的两个值(均从左上方开始移动)

image.png

2、:where() 简化代码

原:
.parentdiv,
.parent.title,
.parent#article {
color: red;
}

改:
.parent:where(div, .title, #article) {
color: red;
}

3、实现平滑滚动

凡是需要滚动的地方都加一句scroll-behavior:smooth 来提升滚动体验!

a、经常使用的锚点定位功能就有了平滑定位功能,如
<a href="#">返回顶部</a>

b、全局css中也建议添加
html, body { scroll-behavior:smooth; }

4、背景混合模式

.blend-2 {
background-image: url(../xx/xxx.jpg);
width: 100vw;
height: 500px;
background-color: #20126f;
background-size: cover;
background-blend-mode: overlay;
}

background-blend-mode分为如下几种模式 

normal:默认值。设置正常的混合模式
multiply:正片叠底模式
screen:滤色模式
overlay:叠加模式
darken:变暗模式
lighten:变亮模式
color-dodge:颜色减淡模式
saturation:饱和度模式
color:颜色模式
luminosity:亮度模式

5、图像填充文字效果

background-clip 属性规定背景的绘制区域

border-box:以盒边界来裁剪
padding-box:以内边距为边界来裁剪
content-box:以内容区域来裁剪

回归主题:
background-clip: text; 顾名思义 就是 以文字的范围来裁剪背景图片

h1 {
background-image: url('./flower.jpg');
background-clip: text;
  -webkit-background-clip: text;
color: transparent;
background-color: white;
}

6288846-7e1313b193b2ce4e.jpg

6、文字描边效果

div{
color: #fff;
font-size: 80px;
  -webkit-text-stroke: 2px blue;
text-stroke: 2px blue;
}

<div>
这是文本。
</div>

text-stroke 属性值中有两部分,第一部分是文字描边的宽度,第二部分是文字描边的颜色。

image.png

7、将文本设为大写或小写

/* 大写 */
.upper {
  text-transform: uppercase;
}

/* 小写 */
.lower {
  text-transform: lowercase;
}

<div class="upper">
    fdsdsdsd
</div>
<divclass="lower">
    DFDSWRREE
</div>

image.png

8、暂停/播放伪类

:paused 伪类可以为处于暂停状态的媒体元素设置样式

video:paused {
opacity: 0.6;
}

需要注意,目前仅 Safari 支持该伪类:paused

9、毛玻璃特效

.login {
backdrop-filter: blur(5px);
}

其他参数:
blur()

模糊: blur(5px)
亮度: brightness(1.4)
对比度: contrast(2)
投影: drop-shadow(4px4px8px#fff)
灰度: grayscale(60%)
色调变化: hue-rotate(66deg)
反相: invert(60%)
透明度: opacity(50%)
饱和度: saturate(250%)
褐色: sepia(70%)

image.png

10、自定义光标

body{  
cursor: url("path-to-image.png"), auto;
}

cursor 内置属性:

default      默认光标(通常是一个箭头)
auto         默认。浏览器设置的光标
crosshair    光标呈现为十字线
pointer      光标呈现为指示链接的指针(一只手)
move         此光标指示某对象可被移动
e-resize     此光标指示矩形框的边缘可被向右(东)移动
ne-resize    此光标指示矩形框的边缘可被向上及向右移动(北/东)
nw-resize    此光标指示矩形框的边缘可被向上及向左移动(北/西)
n-resize     此光标指示矩形框的边缘可被向上(北)移动
se-resize    此光标指示矩形框的边缘可被向下及向右移动(南/东)
sw-resize    此光标指示矩形框的边缘可被向下及向左移动(南/西)
s-resize     此光标指示矩形框的边缘可被向下移动(南)
w-resize     此光标指示矩形框的边缘可被向左移动(西)
text         此光标指示文本
wait         此光标指示程序正忙(通常是一只表或沙漏)
help         此光标指示可用的帮助(通常是一个问号或一个气球

11、裁剪各种形状

div {
height: 150px;
width: 150px;
background-color: crimson;
}

语法详解
1、矩形:
inset() : 定义一个矩形 。注意,定义矩形不是rect,而是 inset
inset()可以传入5个参数,分别对应top,right,bottom,left的裁剪位置,round radius(可选,圆角)

//示例
clip-path: inset(2em3em2em1em round 2em);

2、圆形:
circle() : 定义一个圆
circle()可以传人2个可选参数;
a. 圆的半径,默认元素宽高中短的那个为直径,支持百分比
b. 圆心位置,默认为元素中心点

//示例
clip-path: circle(30% at 150px120px);

3、椭圆:
ellipse() : 定义一个椭圆 
ellipse()可以传人3个可选参数;
a. 椭圆的X轴半径,默认是宽度的一半,支持百分比
b. 椭圆的Y轴半径,默认是高度的一半,支持百分比
c. 椭圆中心位置,默认是元素的中心点

//示例
clip-path: ellipse(45%30% at 50%50%);

4、多边形
polygon() : 定义一个多边形 
//语法
polygon( <fill-rule>? , [ <length-percentage> <length-percentage> ]# )
//说明
<fill-rule>可选,表示填充规则用来确定该多边形的内部。可能的值有nonzero和evenodd,默认值是nonzero
后面的每对参数表示多边形的顶点坐标(X,Y),也就是连接点

//示例
clip-path: polygon(50%0,100%50%,0100%);

其他图形:
矩形:clip-path: inset(5%20%15%10%)
三角形:clip-path: polygon(50%0%, 0%100%, 100%100%)
菱形:clip-path: polygon(50%0%, 100%50%, 50%100%, 0%50%)
梯形:clip-path: polygon(20%0%, 80%0%, 100%100%, 0%100%)
平行四边形:clip-path: polygon(25%0%, 100%0%, 75%100%, 0%100%)
五边形:clip-path: polygon(50%0%, 100%38%, 82%100%, 18%100%, 0%38%)
六边形:clip-path: polygon(50%0%, 100%25%, 100%75%, 50%100%, 0%75%, 0%25%)
七边形:clip-path: polygon(50%0%, 90%20%, 100%60%, 75%100%, 25%100%, 0%60%, 10%20%)
八边形:clip-path: polygon(30%0%, 70%0%, 100%30%, 100%70%, 70%100%, 30%100%, 0%70%, 0%30%)
斜角:clip-path: polygon(20%0%, 80%0%, 100%20%, 100%80%, 80%100%, 20%100%, 0%80%, 0%20%)
槽口:clip-path: polygon(0%15%, 15%15%, 15%0%, 85%0%, 85%15%, 100%15%, 100%85%, 85%85%, 85%100%, 15%100%, 15%85%, 0%85%)
左箭头:clip-path: polygon(40%0%, 40%20%, 100%20%, 100%80%, 40%80%, 40%100%, 0%50%)
右箭头:clip-path: polygon(0%20%, 60%20%, 60%0%, 100%50%, 60%100%, 60%80%, 0%80%)
星星:clip-path: polygon(50%0%, 61%35%, 98%35%, 68%57%, 79%91%, 50%70%, 21%91%, 32%57%, 2%35%, 39%35%)
十字架:clip-path: polygon(10%25%, 35%25%, 35%0%, 65%0%, 65%25%, 90%25%, 90%50%, 65%50%, 65%100%, 35%100%, 35%50%, 10%50%)
叉号:clip-path: polygon(20%0%, 0%20%, 30%50%, 0%80%, 20%100%, 50%70%, 80%100%, 100%80%, 70%50%, 100%20%, 80%0%, 50%30%);
对话框:clip-path: polygon(0%0%, 100%0%, 100%75%, 75%75%, 75%100%, 50%75%, 0%75%)

CSS 的魅力在于它的“以简驭繁”,一个看似简单的属性或技巧,可能就能解决你遇到的大问题。

希望这些常用小技巧能为你的开发工作带来灵感和帮助。如果你也有自己珍藏的 CSS 小技巧,欢迎在评论区交流分享,让我们一起写出更高效、更优雅的样式代码!

关于优联前端

        武汉优联前端科技有限公司由一批从事前端10余年的专业人才创办,是一家致力于H5前端技术研究的科技创新型公司,为合作伙伴提供专业高效的前端解决方案,合作伙伴遍布中国及东南亚地区,行业涵盖广告,教育, 医疗,餐饮等。有效的解决了合作伙伴的前端技术难题,节约了成本,实现合作共赢。承接开发Web前端,微信小程序、小游戏,2D/3D游戏,动画交互与UI广告设计等各种技术研发。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值