SVG 文本(一)text、tspan 的基本使用

简介: SVG 文本(一)text、tspan 的基本使用

一、简介

  • SVG 通过 <text><tspan> 创建文本,支持 <a> 插入超链接,可以通过 <textPath> 让文本在指定的路径上排列。
  • <text><tspan>基本属性:
  • x、y:定位标准
  • dx、dy:字形偏移
  • style:设置样式

二、text

  • 案例
<svg xmlns="http://www.w3.org/2000/svg" width="600" height="400">
    <defs>
      <!-- 网格 -->
      <pattern id="grid" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse">
        <path fill="none" stroke="#f1f1f1" d="M 0 0 H 20 V 20"/>
      </pattern>
    </defs>
    <!-- 设置网格 -->
    <rect width="600" height="400" fill="url(#grid)"/>
    <!-- 小格子内容 -->
    <text x="20" y="20">文本测试</text>
    <!-- 基线对齐效果 -->
    <path d="M 100 0 V 300 M 0 100 H 400 M 0 200 H 400 M 0 300 H 400" stroke="red"/>
    <text x="100" y="100" style="font-size: 50px;">DZM 文本测试</text>
    <!-- dx dy 测试 -->
    <text x="100" y="200" style="font-size: 50px;" dx="10" dy="10">DZM 文本测试</text>
    <text x="100" y="300" style="font-size: 50px;" dx="20 40 60 80" dy="20 20 20 20 20">ABCDEFG</text>
</svg>

三、tspan

  • tspan 标签支持单独配置 dx dy,优先使用自身自带的,后续文字如果没有单独配置,会自动继承上一个文字的 dx dy
<svg xmlns="http://www.w3.org/2000/svg" width="600" height="400">
    <defs>
      <!-- 网格 -->
      <pattern id="grid" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse">
        <path fill="none" stroke="#f1f1f1" d="M 0 0 H 20 V 20"/>
      </pattern>
    </defs>
    <!-- 绘制网格 -->
    <rect width="600" height="400" fill="url(#grid)"/>
    <!-- 基线对齐效果 -->
    <path d="M 100 0 V 300 M 0 100 H 400 M 0 200 H 400 M 0 300 H 400" stroke="red"/>
    <text x="100" y="100" style="font-size: 50px;">
      <tspan fill="red">AB</tspan>
      <tspan stroke="blue" stroke-width="2" fill="red">CDE</tspan>
      <tspan fill="blue">FG</tspan>
    </text>
    <!-- 测试 dx dy 在 tspan 身上的效果 -->
    <text x="100" y="200" style="font-size: 50px;">
      <tspan fill="red" dy="-20">AB</tspan>
      <tspan stroke="blue" stroke-width="2" fill="red" dy="20 -10">CDE</tspan>
      <tspan fill="blue">FG</tspan>
    </text>
    <!-- 测试 dx dy 在 tspan 身上的效果 -->
    <text x="100" y="300" dy="30" style="font-size: 50px;">
      <tspan fill="red">AB</tspan>
      <tspan stroke="blue" stroke-width="2" fill="red" dy="20 -10">CDE</tspan>
      <tspan fill="blue">FG</tspan>
    </text>
</svg>

相关文章
|
5月前
|
前端开发 JavaScript 开发者
CSS进阶 - CSS Modules与预处理器简介
【6月更文挑战第17天】前端开发中,CSS Modules和预处理器(如Sass、Less)解决了大规模项目中CSS的管理难题,提升代码复用和维护性。CSS Modules提供局部作用域的类名,避免全局冲突,而预处理器扩展CSS功能,使代码更像编程语言。常见问题包括命名冲突和过度嵌套,可通过自动哈希、少嵌套、合理变量规划来解决。结合两者使用,遵循模块化和适度预处理原则,集成到构建工具中,能优化开发流程。这些技术是现代前端不可或缺的工具。
68 2
|
2月前
|
JavaScript 前端开发 Python
JavaScript写个.ts视频文件Url生成器,使用了string.padStart
JavaScript写个.ts视频文件Url生成器,使用了string.padStart
|
1月前
|
安全 前端开发 开发者
CSS3 中 calc()、constant() 和 env() 函数的使用指南
在现代网页设计中,CSS3 的 calc()、constant() 和 env() 函数为开发者提供了强大的工具,帮助实现灵活和响应式的布局。本文将深入探讨这三个函数的定义、用法以及最佳实践,特别是如何利用 calc() 进行动态计算、constant() 的历史背景,以及 env() 在处理设备安全区域中的应用。通过本文,读者将能够更好地理解并运用这些函数,提升网页设计的灵活性与用户体验。
22 0
|
6月前
|
小程序 前端开发
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
content‘ is declared but its value is never read.富文本编辑器中这里必须的script中添加setup,引入到set当中时,带title的富文本写法
content‘ is declared but its value is never read.富文本编辑器中这里必须的script中添加setup,引入到set当中时,带title的富文本写法
|
6月前
|
前端开发
css教程-li的list-style-type属性
通过设置 `list-style-type`属性,你可以根据需求为列表项设置不同的标志样式,从而改变列表的外观。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
62 4
|
6月前
|
JavaScript
vue element upload组件配合axios实现用 “Content-Type“: “multipart/form-data“上传方式导入xls文件
vue element upload组件配合axios实现用 “Content-Type“: “multipart/form-data“上传方式导入xls文件
|
6月前
|
移动开发 小程序 JavaScript
uView Text 文本
uView Text 文本
54 1
|
6月前
highlight.line-numbers.js下载及使用
highlight.line-numbers.js下载及使用
75 1
|
6月前
|
前端开发 JavaScript 容器
你知道css中的object-fit的用法吗?
你知道css中的object-fit的用法吗?
160 0