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>

相关文章
|
9月前
SVG 文本(二)路径文本 <textPath>
SVG 文本(二)路径文本 <textPath>
97 0
|
4天前
|
小程序 前端开发
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
【微信小程序】-- 常用的基础内容组件介绍 -- text & rich-text & progress & icon(七)
|
4天前
|
前端开发
css教程-li的list-style-type属性
通过设置 `list-style-type`属性,你可以根据需求为列表项设置不同的标志样式,从而改变列表的外观。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
17 4
|
4天前
|
JavaScript
vue element upload组件配合axios实现用 “Content-Type“: “multipart/form-data“上传方式导入xls文件
vue element upload组件配合axios实现用 “Content-Type“: “multipart/form-data“上传方式导入xls文件
|
4天前
|
移动开发 小程序 JavaScript
uView Text 文本
uView Text 文本
23 1
|
4天前
|
SQL 数据可视化 数据库
Python中表格插件Tabulate的用法
Python中表格插件Tabulate的用法
69 0
|
7月前
|
JavaScript 前端开发 应用服务中间件
关于 Angular 部署以及 index.html 里 base hRef 属性的关联关系
关于 Angular 部署以及 index.html 里 base hRef 属性的关联关系
59 0
|
8月前
|
JavaScript
jQuery val(); input 获取与设置默认输入内容
jQuery val(); input 获取与设置默认输入内容
46 0
Angular应用Base Element Href属性的设置
Angular应用Base Element Href属性的设置
Angular应用Base Element Href属性的设置
Angular html property的值如何被更新的
Angular html property的值如何被更新的
Angular html property的值如何被更新的