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 相关文章推荐
jQuery is()函数用法3例
May 06 Javascript
jquery.form.js实现将form提交转为ajax方式提交的方法
Apr 07 Javascript
JavaScript如何自定义trim方法
Jul 28 Javascript
学习AngularJs:Directive指令用法(完整版)
Apr 26 Javascript
js实现的页面加载完毕之前loading提示效果完整示例【附demo源码下载】
Aug 02 Javascript
JS中关于事件处理函数名后面是否带括号的问题
Nov 16 Javascript
详解vue.js全局组件和局部组件
Apr 10 Javascript
vue2.0 axios前后端数据处理实例代码
Jun 30 Javascript
element-ui的回调函数Events的用法详解
Oct 16 Javascript
微信小程序如何实现在线客服功能
Oct 16 Javascript
vue使用一些外部插件及样式的配置代码
Nov 18 Javascript
微信小程序swiper组件实现抖音翻页切换视频功能的实例代码
Jun 24 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
xml+php动态载入与分页
2006/10/09 PHP
计算2000年01月01日起到指定日的天数
2006/10/09 PHP
php 操作excel文件的方法小结
2009/12/31 PHP
PHP SEO优化之URL优化方法
2011/04/21 PHP
php中OR与|| AND与&amp;&amp;的区别总结
2013/10/26 PHP
详解 PHP加密解密字符串函数附源码下载
2015/12/18 PHP
编写PHP脚本清除WordPress头部冗余代码的方法讲解
2016/03/01 PHP
深入浅析yii2-gii自定义模板的方法
2016/04/26 PHP
PHP实现用户登录的案例代码
2018/05/10 PHP
jquery api参考 visualjquery 中国线路 速度快
2007/11/30 Javascript
EXTjs4.0的store的findRecord的BUG演示代码
2013/06/08 Javascript
javascript实现3D变换的立体圆圈实例
2015/08/06 Javascript
Javascript实现快速排序(Quicksort)的算法详解
2015/09/06 Javascript
利用BootStrap弹出二级对话框的简单实现方法
2016/09/21 Javascript
深入理解javascript中concat方法
2016/12/12 Javascript
Ajax实现不刷新取最新商品
2017/03/01 Javascript
vue+mockjs模拟数据实现前后端分离开发的实例代码
2017/08/08 Javascript
vue中实现移动端的scroll滚动方法
2018/03/03 Javascript
Vue数据双向绑定的深入探究
2018/11/27 Javascript
js+canvas实现画板功能
2020/09/13 Javascript
浅谈JSON5解决了JSON的两大痛点
2020/12/14 Javascript
[03:16]DOTA2完美大师赛小组赛精彩集锦
2017/11/22 DOTA
Python多线程爬虫简单示例
2016/03/04 Python
使用Python的Flask框架构建大型Web应用程序的结构示例
2016/06/04 Python
Python 20行简单实现有道在线翻译的详解
2019/05/15 Python
使用python制作一个为hex文件增加版本号的脚本实例
2019/06/12 Python
利用Python如何制作贪吃蛇及AI版贪吃蛇详解
2020/08/24 Python
adidas瑞典官方网站:购买阿迪达斯鞋子和运动服
2019/12/11 全球购物
早读迟到检讨书
2014/01/24 职场文书
支行行长竞聘演讲稿
2014/05/15 职场文书
嘉宾邀请函
2015/01/31 职场文书
先进工作者个人总结
2015/02/15 职场文书
个人欠条范本
2015/07/03 职场文书
详解Go语言中Get/Post请求测试
2022/06/01 Golang
springboot为异步任务规划自定义线程池的实现
2022/06/14 Java/Android
React如何使用axios请求数据并把数据渲染到组件
2022/08/05 Javascript