【CSS】文字描边的三种实现方式

目录

1. 可行的几种方式

  • text-shadow
  • --webkit-text-stroke
  • svg

1.1. text-shadow 描边

MDN text-shadow

代码

html 复制代码
<div class="text stroke">新年快乐</div>

用 text-shadow 实现八个方向的文字阴影。

css 复制代码
.text {
	font-size: 150px;
	color: white;
	font-weight: 400;
}

.stroke {
	text-shadow: 4px 0 #000,
	-4px 0 #000,
	0 4px #000,
	0 -4px #000,
	4px 4px #000,
	-4px -4px #000,
	4px -4px #000,
	-4px 4px #000;
}

优缺点

优点

  • 兼容性好

缺点

  • 文字边缘会有锯齿。

如上图,当文字很大时,尤其明显。因为我们只设置了8个方向的阴影,这些方向交界处容易出问题。

  • 文字必须设置颜色

如果我们把文字设置为透明色,描边就失效了,因为text-shadow本质就是设置文本阴影。

css 复制代码
color: transparent;

效果:文字透明了,文字阴影彻底显现了出来。

1.2. text-stroke 描边

MDN text-stroke

实现

html 复制代码
<div class="text stroke">新年快乐</div>
css 复制代码
.text {
	font-size: 150px;
	color: white;
	font-weight: 400;
}

.stroke {
	-webkit-text-stroke: 4px #000;
}

可以实现丝滑的描边效果!

注意:text-stroke 是居中描边 ,我们这里设置了 4px 的描边,实际上会在文字内部和外部各画2px。直接使用 text-stroke 来描边会让文字本身变瘦

比如,我们继续加大描边的宽度,设置8px。

CSS 复制代码
-webkit-text-stroke: 8px #000;

可以看到最终的效果是文字的白色部分越来越少。

如果你觉得这样无所谓,那这样实现也可以。但如果你不想要文字本身的宽度(白色部分)改变,那么可以用下面的技巧来实现。

我们增加一个伪元素来,完整代码如下:

html 复制代码
<div class="text stroke" data-content="2023, 新年快乐!">2023, 新年快乐!</div>
css 复制代码
.text {
	font-size: 150px;
	color: white;
	font-weight: 400;
	position: relative;
	z-index: 0;
}

.text::after {
	content: attr(data-content);
	-webkit-text-stroke: 8px #000;
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
}

这里我们给伪元素设置描边,并且将原本的文字覆盖在其上面,能完美实现描边,且没有改变原本的文字宽度。

注意:我们原本想实现4px的描边,前面我们提到text-stroke是居中描边,因此为了实现效果我们实际上要设置8px。

优缺点

优点

  • 效果好,描边丝滑。

缺点

  • 兼容性一般,需要加 -webkit 前缀

1.3. svg 描边

实现

html 复制代码
<svg xmlns="http://www.w3.org/2000/svg" width="1200" height="200">
 <text 
    class="text stroke"
    x="0" 
    y="0" 
    alignment-baseline="text-before-edge" 
    text-anchor="start"
  >
    2023, 新年快乐!
  </text>
</svg>
css 复制代码
.text {
  font-size: 150px;
  fill: white;
  font-weight: 400;
}

.stroke {
  stroke: #000;
  stroke-width: 4px;
}

通过设置stroke + stroke-width 即可实现描边。

注意:这里实现的效果也类似前面 text-stroke 的居中描边,实际上文字本身也变瘦了。

为了不让文字本身变瘦,我们可以用paint-order属性来改变描边绘制的方式。

css 复制代码
.stroke {
  stroke: #000;
  stroke-width: 8px;
  paint-order: stroke;
}

同样实现了描边效果,且不改变文字原本宽度。

优缺点

优点

  • 兼容性最好
  • 通过 stroke-linejoin 属性,还可以对 svg 的描边有更灵活的控制
css 复制代码
.stroke1 {
  stroke-linejoin: round;
}

.stroke2 {
  stroke-linejoin: bevel;
}

.stroke3 {
  stroke-linejoin: miter;
}

缺点

  • 需要设置svg 的宽高,文字排版可能不够灵活

总结

我们介绍了css中三种文字描边的实现方式,它们各有优缺点,可以根据实际的应用场景选择最合适的方式!

相关推荐
anyup5 小时前
全面重构的 uni-app 多平台上传组件,功能强到离谱!
前端·vue.js·uni-app
小赵同学WoW5 小时前
作用域链与闭包
前端
暗不需求5 小时前
告别“class 命名地狱”:从面向对象 CSS 到原子 CSS(Tailwind) 的思维跃迁
前端·css·react.js
幼儿园技术家5 小时前
前端如何做监控体系(埋点 → 上报 → 分析 → 数据分流)
前端·js or ts
盖丽男5 小时前
彻底搞懂:前端MVVM、后端MVC、DDD极致面向对象的区别与落地真相
前端·mvc
澄江静如练_5 小时前
vue2中使用provide和inject出现的问题
前端·vue
星辰徐哥6 小时前
表单优化:AI驱动HTML5表单的智能验证与提示功能
前端·人工智能·html5
普通网友6 小时前
HTML5新增了哪些重要标签?多多学习也是成长的一部分
前端·学习·html5
2501_906467636 小时前
html5网页中如何实现内网大文件的加密下载?
前端·html·html5·vue上传解决方案·vue断点续传·vue分片上传下载·vue分块上传下载
极客小俊6 小时前
【从零到一】用HTML5+CSS+JavaScript实现一个属于自己的mp3免费音乐播放器 (4) JS交互功能(音乐进度条)
javascript·css·html5·前端开发·免费教程·代码案例·手搓音乐播放器