CSS中制作环形文本的方法及代码是什么
Admin 2022-08-24 群英技术资讯 364 次浏览
在项目开发中,我们可能会遇到环形文本的需求,这个时候,怎样在代码以通俗易懂的前提下实现我们需要的效果呢?可能你会想到用一个一个的span元素计算出旋转的角度然后拼接起来,这个方案不仅非常麻烦,而且还给页面的DOM元素添加了很多不必要的臃肿的标记著作权归作者所有。你可能也会想到既然怕麻烦,不如就用图片吧,简单粗暴多好,可是这样的话后期如果要修改就需要修改原始图片,这不是我们想要的效果,那如何才能用css实现我们想到的效果呢,
我们可以通过一点内联SVG来很简单地完成。SVG本身就支持文本以任何路径显示,环形只不过是路径的一个特殊情况。我们来试一下!
SVG中文本按路径显示的基本方案是通过一个<textPath>
元素来包裹我们的文本,把它放到一个<text>
元素中。<textPath>
元素通过id
引用我们的路径中定义的<path>
元素。在内联SVG中的文本还继承了我们的字体样式(除了line-height
,因为这是SVG中默认的样式),所以我们不需要担心这个问题,就像我们引入一个外部的SVG图像一样。
可惜,
<textPath>
只可以存在于<path>
元素中,这就是我们为什么不可以使用可读性更好的<circle>
元素作为我们的路径圆的原因。
假设我们要把“circular reasoning works because”这句话做成环形文本,占据一个圆圈的整个圆周,如图所示。
html:
<div class="circular"> <svg viewBox="0 0 100 100"> <path d="M 0,50 a 50,50 0 1,1 0,1 z" /> <text> <textPath xlink:href="#circle"> circular reasoning works because </textPath> </text> </svg> </div>
css:
.circular{ width: 200px; height: 200px; margin: 100px; } .circular path { fill: none; } .circular svg { display: block; overflow: visible; }
好了,基础的代码就是这些,这样就可以实现一个环形文本的效果了,如果项目中有多个地方需要用到环形文本,但是你也不想写那么多重复的html元素,这个时候你可以用一段js为容器(.circular)添加内部元素:
function $$(selector, context) { context = context || document; var elements = context.querySelectorAll(selector); return Array.prototype.slice.call(elements); } $$('.circular').forEach(function(el) { var NS = "http://www.w3.org/2000/svg"; var svg = document.createElementNS(NS, "svg"); svg.setAttribute("viewBox", "0 0 100 100"); var circle = document.createElementNS(NS, "path"); circle.setAttribute("d", "M0,50 a50,50 0 1,1 0,1z"); circle.setAttribute("id", "circle"); var text = document.createElementNS(NS, "text"); var textPath = document.createElementNS(NS, "textPath"); textPath.setAttributeNS("http://www.w3.org/1999/xlink", 'xlink:href', '#circle'); textPath.textContent = el.textContent; text.appendChild(textPath); svg.appendChild(circle); svg.appendChild(text); el.textContent = ''; el.appendChild(svg); });
页面中需要环形文本的地方加上容器就行:
<div class="circular">这里是环形文本这里是环形文本</div> <div class="circular">这里是环形文本这里是环形文本2</div>
效果如下:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
给元素设置圆角半径的css属性是border-radius。border-radius属性可以设置元素的外边框圆角;使用 CSS3 border-radius 属性,你可以给任何元素制作 "圆角"。语法:border-radius:
这篇文章主要介绍了css3媒体查询中device-width和width的区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
在一些网页设计中,我们会看到字体渐变效果,而想要实现字体渐变效果其实不难,这篇文章就给大家来分享一下css3实现字体渐变效果的内容,实现代码及效果如下,感兴趣的朋友可以参考。
用css怎么做卡券?现在很多网站或者购物商场都会推出优惠卡或者礼品券等等这些,而实现这些卡券效果其实并不难,下面就给大家分享一下怎样使用CSS实现多种样式的额卡券。
这篇文章给大家分享的是移动端flex布局中单行和双行效果的实现。小编觉得挺实用的,因此分享给大家做个参考,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008