D3.js实现文本的换行详解


Posted in Javascript onOctober 14, 2016

一、文字换行是什么问题?

现有一字符串:

var str = "云中谁寄锦书来,雁字回时,月满西楼";

李清照的一剪梅,读过吗?

body 里添加一个 svg 元素,大小如下:

var width = 300; 
var height = 300; 
   
var svg = d3.select("body") 
  .append("svg") 
  .attr("width",width) 
  .attr("height",height);

然后添加文字,用 text 元素,这样的代码我们很熟悉了:

var text = svg.append("text") 
  .attr("x",30) 
  .attr("y",100) 
  .attr("font-size",30) 
  .attr("font-family","simsun") 
  .text(str);

结果如下:

D3.js实现文本的换行详解

可以看到,虽然 text 元素标签的内容有整个字符串,但是由于 svg 的宽度只有 300,显示不了这么长的字符串,因此多余的部分看不到。

怎么办?自然是要换行。

二、在 text 中添加 tspan 子元素

SVG 中的文本不支持自动换行,需要手动实现。其中一种方法就是使用 tspan 标签。

tspan 是写在 text 中的,作为其子元素存在。设置文本属性的时候,有一个 dy 属性,表示 y 轴的相对位移,dy 的值通常用 10px、1em 这样的值,其中 em 是以行为单位的。

这样,我们就可以在 text 中添加多个 tspan ,每个代表一行。每一个 tspan 属性都赋予一个 1em 值(即一行)。如此,文本就会一行一行地显示了。

svg代码为:

<text x="30" y="100" font-size="30" font-family="simsun"> 
<tspan x="30" dy="1em">夜来幽梦忽还乡</tspan> 
<tspan x="30" dy="1em">小轩窗</tspan> 
<tspan x="30" dy="1em">正梳妆</tspan> 
</text>

要注意,tspan 中的 x 属性是必要的,表示下一行也从 x = 30 处开始显示。

三、D3 的代码怎么写

对于第一节的字符串,先在 svg 中添加一个 text 元素,但是不设定其内容。

var str = "云中谁寄锦书来,雁字回时,月满西楼";   
  
var text = svg.append("text") 
    .attr("x",30) 
    .attr("y",100) 
    .attr("font-size",30) 
    .attr("font-family","simsun");

使用 JavaScript 字符串的 split str 分段:

var strs = str.split(",") ;

用逗号作为分隔符,分为几段。输出结果为一个数组,数组中的各项是各子字符串。则 strs 的值为:

["云中谁寄锦书来", "雁字回时", "月满西楼"]

好,接下来是重点,在 text 元素上绑定数据,并添加与 strs 长度相同的 tspan 元素。然后,为其 xdy 属性赋值,再指定字符串内容即可。

代码如下:

text.selectAll("tspan") 
  .data(strs) 
  .enter() 
  .append("tspan") 
  .attr("x",text.attr("x")) 
  .attr("dy","1em") 
  .text(function(d){ 
   return d; 
  });

结果如下:

D3.js实现文本的换行详解

到这我们就基本完成了,下面给大家奉上完整的示例代码,有需要的可以参考。

完整实例代码如下

<html>
 <head>
  <meta charset="utf-8"> 
  <title>文字换行</title> 
 </head> 
 <body> 
 <script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script> 
  <script>  
 
 var width = 300;
 var height = 300;
 
 var svg = d3.select("body")
  .append("svg")
  .attr("width",width)
  .attr("height",height);

 var str = "云中谁寄锦书来,雁字回时,月满西楼"; 
 
 var text = svg.append("text")
  .attr("x",30)
  .attr("y",100)
  .attr("font-size",30)
  .attr("font-family","simsun");
  
 var strs = str.split(",") ;
 
 console.log(strs);
  
 text.selectAll("tspan")
 .data(strs)
 .enter()
 .append("tspan")
 .attr("x",text.attr("x"))
 .attr("dy","1em")
 .text(function(d){
  return d;
 });
 
  
  </script> 
 
 </body> 
</html>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用D3.js能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
js点击页面其它地方将某个显示的DIV隐藏
Jul 12 Javascript
js函数与php函数的区别实例浅析
Jan 12 Javascript
jQuery+jRange实现滑动选取数值范围特效
Mar 14 Javascript
jquery点击缩略图切换视频播放特效代码分享
Sep 15 Javascript
基于javascript html5实现多文件上传
Mar 03 Javascript
简单的分页代码js实现
May 17 Javascript
javascript简易画板开发
Apr 12 Javascript
基于vue.js路由参数的实例讲解——简单易懂
Sep 07 Javascript
浅谈vue-cli 3.0.x 初体验
Apr 11 Javascript
CSS3 动画卡顿性能优化的完美解决方案
Sep 20 Javascript
JavaScript中的一些实用小技巧总结
Apr 07 Javascript
vue页面更新patch的实现示例
Mar 25 Javascript
Bootstrap企业网站实战项目4
Oct 14 #Javascript
Bootstrap在线电子商务网站实战项目5
Oct 14 #Javascript
纯JS打造网页中checkbox和radio的美化效果
Oct 13 #Javascript
angularjs 中$apply,$digest,$watch详解
Oct 13 #Javascript
jQuery鼠标事件总结
Oct 13 #Javascript
BootStrap实现邮件列表的分页和模态框添加邮件的功能
Oct 13 #Javascript
jQuery中delegate()方法的用法详解
Oct 13 #Javascript
You might like
php实现无限级分类查询(递归、非递归)
2016/03/10 PHP
五段实用的js高级技巧
2011/12/20 Javascript
JS实现局部选择打印和局部不选择打印
2014/04/03 Javascript
jquery如何扑捉回车键触发的事件
2014/04/24 Javascript
js加减乘除丢失精度问题解决方法
2014/05/16 Javascript
jQuery实现的Div窗口震动特效
2014/06/09 Javascript
node.js中的events.emitter.once方法使用说明
2014/12/10 Javascript
分享一个自己写的简单的javascript分页组件
2015/02/15 Javascript
javascript中不易分清的slice,splice和split三个函数
2016/03/29 Javascript
实现React单页应用的方法详解
2016/08/02 Javascript
微信小程序 常用工具类详解及实例
2017/02/15 Javascript
Angularjs上传文件组件flowjs功能
2017/08/07 Javascript
纯js封装的ajax功能函数与用法示例
2018/05/14 Javascript
微信小程序在线客服自动回复功能(基于node)
2019/07/03 Javascript
微信小程序云函数使用mysql数据库过程详解
2019/08/07 Javascript
vue切换菜单取消未完成接口请求的案例
2020/11/13 Javascript
Python中list列表的一些进阶使用方法介绍
2015/08/15 Python
django缓存配置的几种方法详解
2018/07/16 Python
详解将Django部署到Centos7全攻略
2018/09/26 Python
Python读取xlsx文件的实现方法
2019/07/04 Python
python实现七段数码管和倒计时效果
2019/11/23 Python
python中requests模拟登录的三种方式(携带cookie/session进行请求网站)
2020/11/17 Python
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
2016/02/27 HTML / CSS
几个解决兼容IE6\7\8不支持html5标签的几个方法
2013/01/07 HTML / CSS
纽约通行卡:The New York Pass(免费游览纽约90多个景点)
2017/07/29 全球购物
工程造价自荐信
2013/10/09 职场文书
令人啧啧称赞的经理推荐信
2013/11/07 职场文书
装潢设计专业推荐信模板
2013/11/26 职场文书
廉政文化进校园广播稿
2014/10/20 职场文书
幼儿园小班个人总结
2015/02/12 职场文书
导游词范文
2015/02/13 职场文书
优秀团员个人总结
2015/02/26 职场文书
大学生预备党员自我评价
2015/03/04 职场文书
2015年民主评议党员工作总结
2015/05/19 职场文书
Python基础之元类详解
2021/04/29 Python
深入理解以DEBUG方式线程的底层运行原理
2021/06/21 Java/Android