d3代码如何改造成update结构(恰当处理enter和exit)

d3的enter和exit

网上有很多blog讲解。说的还凑合的见:https://blog.csdn.net/nicolecc/article/details/50786661

如何把自己的rude绘图代码,进行精致化(update)

 不多比比,上代码示例:

d3.selectAll('.circle_group').children().remove();
var circle_group = d3.selectAll('.circle_group').data(circleData).enter().append('g').attr('class', 'circle_group brushNode').attr('transform',function (d) {return 'translate(' + d.x + ',' + d.y + ')';}).on('click', function (d) {if (shiftKey) {//标记当前点d3.select(this).classed("selected", function (d) {d.selected = !d.selected;d.previouslySelected = !d.selected;return d.selected;})//阻止事件冒泡
            d3.event.stopPropagation();}}).on("contextmenu", function (node) {contextmenu("Rmenu");})circle_group.append('circle').attr('r', function (d) {return d.r;}).style("fill", function (d) {return color20(d.index);});
circle_group.append('text').attr("dy", ".35em").attr("text-anchor", "middle")//在圆圈中加上数据.style('fill', function (node) {return '#555';}).attr("y", -7).text(d => d.text);circle_group.call(d3.drag()
//定义了元素拖拽行为的原点,设置为圆的圆心位置可以避免明显的元素跳动, 与d3v3中的origin方法类似。.subject(function () {var thisData = d3.select(this);return {x: thisData.datum().x,y: thisData.datum().y};}).on("start", dragstarted).on("drag", dragmove).on("end", dragended));

 很明显,新手图省事都是这么绘图的。就绘图结果来看,如果你不加动画一点问题都没有,只要一加动画过渡动画,所有的图形都是从无到有的过程,而我们想看的是,如果点更新的话,能看到他从哪(位置)更新到哪(位置)。(这里就不加动画过渡了,就一行代码的事.transition().duration(300) )。

改造如下:

    //这部分代码是有则改之,无则添加的功能
const circle_data=d3.selectAll('.circle_group').data(circleData)  //更新部分,如果你数据的数目没变,那circle_data.size()=你数据内容改变的数目,你可以把circle_data考虑成update部分就行,这样编代码准没错.attr('transform',             //首次运行的时候,因为没有元素circle_data.size()=0, 所以这个transform不会运行到function (d) {return 'translate(' + d.x + ',' + d.y + ')';});
const circle_enter=circle_data.enter().append('g')  //add 部分,首次运行的时候,circle_enter.size()=全部元素,所以在circle_enter进行所有的初始化设置操作.attr('class', 'circle_group brushNode').attr('transform',function (d) {return 'translate(' + d.x + ',' + d.y + ')';});
circle_data.exit().remove();  // 当你删一些数据的时候, .exit().size()>0
circle_enter.on('click', function (d) {if (shiftKey) {//标记当前点d3.select(this).classed("selected", function (d) {d.selected = !d.selected;d.previouslySelected = !d.selected;return d.selected;})//阻止事件冒泡
        d3.event.stopPropagation();}
}).on("contextmenu", function (node) {contextmenu("Rmenu");})circle_enter.append('circle')     //add.attr('r', d=>d.r).style("fill", function (d) {return color20(d.index);});
circle_data.select('circle')  //update,这里不要append ,因为元素已经在那了(enter().append()过了)。当然首次运行(视图首次显示)的时候,这几句代码是运行不到的。.attr('r', d=>d.r).style("fill", function (d) {return color20(d.index);});circle_enter.append('text')  //add.attr("dy", ".35em").attr("text-anchor", "middle")//在圆圈中加上数据.style('fill', function (node) {return '#555';}).attr("y", -7).text(d => d.text);
circle_data.select('text')  //update  不要append .text(d => d.text);const drag=d3.drag()
//定义了元素拖拽行为的原点,设置为圆的圆心位置可以避免明显的元素跳动, 与d3v3中的origin方法类似。.subject(function () {var thisData = d3.select(this);return {x: thisData.datum().x,y: thisData.datum().y};}).on("start", dragstarted).on("drag", dragmove).on("end", dragended);
circle_enter.call(drag);
circle_data.call(drag);   //update 注意,这里一定要重新绑定一下,这里涉及到drag的初始化(subject用于初始化drag拖动点的初始位置)

 

敲黑板

1、更新部分的所有与位置有关的事件(比如d3.drag()的初始位置)要重新绑定,否则会出现不可预料的结果。

2、update部分与数据有关的attr,style要重新设置,这时就不用append了。(因为这个元素既然有了,你已经在之前的.enter().append().append(其他元素)添加过了,这里只需要更新一下即可。)。一些固定的attr,style就不用重复设置了(之前enter已经绑定过了)

转载于:https://www.cnblogs.com/xunhanliu/p/10995687.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448756.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

退居二线VS在深圳发展,一个十年IT人的选择之难

有的人一直以来,身体里彷佛住着两个灵魂。一个灵魂说:人就要拼搏,要奋斗,要实现理想,要留在中国最繁华的城市,感受大都市的生活,实现个人价值,走上人生巅峰!另一个灵魂说…

Jenkins 详细安装、构建部署 使用教程

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,功能包括&…

GPU并行计算版函数图像生成器

前几天技术大牛Vczh同学开发了一个函数图像绘制程序,可以画出方程f(x,y)0的图像。他的原理是用图像上每一点的坐标带入函数f得到针对x和y的两个方程,再用牛顿迭代法求解得到一组点集,然后画到图像上。用他的程序可以画出各种各样令人惊叹的方…

完全平方公式、平方差公式、一个数负次方

1.完全平方公式: 两数和(或差)的平方,等于它们的平方和,加上(或减去)它们的积的2倍即完全平方公式 (ab)2a2b22ab 两数和的完全平方公式(完全平方和) 与(a-b)2a2b2-2ab …

WSS连接服务器端报错

错误: 1. Firefox 和 Chrome 浏览器对SSL证书拒绝的错误提示是不一样的: (1) Chrome报错:WebSocket connection failed: Error in connection establishment: net::ERR_CERT_AUTHORITY_INVALID (2&#xff…

LogBack 入门实践

一、简介 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 LogBack是一个日志框架,它是Log4j作者Ceki的又一个日志组件。 LogBack,Slf4j,Log4j之间的关系 slf4j是The Simp…

20个公司绝对不会告诉你的潜规则

1.入职时的工资高低不重要,只要你努力工作你会得到相应待遇的    我估计几乎找过工作的人都听过这句话,当我们确定被聘用跟公司谈工资时,他们都会说“如果以后你业绩突出、努力工作,你的报酬也会相应增加的”,特别是…

java 复制文件

2019独角兽企业重金招聘Python工程师标准>>> public class copyFIle { public static void main(String[] args) throws IOException { File source new File("d:/test/1.xml");File des new File("d:/test/ma.txt");InputStream input null;…

Quartz学习资料地址记录 、Quartz 学习的博客地址记录

Quartz专栏系列 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 1.Quartz学习——Quartz大致介绍(一) 2.Quartz学习——Quartz简单入门Demo(二&#…

民间75个不传之密 ,医院都不知道的秘密

1、头痛(各种头痛均可): 生白萝卜汁,每次滴鼻孔两滴(两鼻孔都滴),一日两次,连用4-5天,可除根。忌吃花椒、胡椒。 2、头晕(头昏眼花、晕眩): 鸭蛋一个、赤豆2…

Docker最全教程之MySQL容器化 (二十四)

Docker最全教程之MySQL容器化 (二十四) 原文:Docker最全教程之MySQL容器化 (二十四)前言 MySQL是目前最流行的开源的关系型数据库,MySQL的容器化之前有朋友投稿并且写过此块,本篇仅从笔者角…

CODING 受邀参加《腾讯全球数字生态大会》

近日,腾讯全年最重要的一场活动——《腾讯全球数字生态大会》于昆明滇池国际会展中心正式举办。此次全球数字生态大会是腾讯战略升级后,整合互联网数字经济峰会、云未来峰会、腾讯全球合作伙伴三大行业大会,全新升级打造的行业创新大会。大会…

解决 dockerfile 构建镜像报错: [WARNING]: Empty continuation lines will become errors in a future release.

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 1. 只是想自己写个 dockerfile 用 docker 来部署 rocketmq 的服务。 dockerfile 中要运行多行命令 于是我写成 RUN 命令a \&&…

第二章:08运算符[比较运算符]

①比较运算符②实例/* 运算符之三&#xff1a;比较运算符 ! > < > < instanceof 结论&#xff1a; 1.比较运算符的结果是boolean类型 2.区分 和 */ class CompareTest { public static void main(String[] args) { int i 10; int j 20; System.out.pr…

Apache版本兼容性问题

Apache 版本2.2.31 版本对于谷歌浏览器不兼容、IE8版本可以正常使用 当使用了Apache 高版本的话就解决了 出现以下现象 转载于:https://www.cnblogs.com/tzhyy/p/10931084.html

王淮经验谈:我的码农原则

摘要&#xff1a;王淮是Facebook第二位中国籍工程师&#xff0c;也是第一位中国籍研发经理&#xff0c;他一手开创了Facebook的支付安全和客服工具领域。2011年他离开Facebook&#xff0c;回国成为天使投资人。本文是王淮以前写代码和做代码审查时候的一些原则&#xff0c;供大…

centos uwsgi自动调用python2环境,指定uwsgi调用版本

将自己开发好的django项目用uwsgi部署到Linux服务器、当运行uwsgi时出现了uwsgi选择python版本的问题。因为本机器是在原来的机器上安装了python3环境和pip3&#xff0c; 使用命令安装uwsgi: pip3 install uwsgi 一点问题也没有&#xff0c;使用uwsgi部署项目时 uwsgi --http :…

docker build Dockfile ---- RUN 中 cd 切换路径失败 的原因、解决

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 我只是想 直接切换到对应目录下 执行后续命令。 ​​​​​写法如下&#xff1a; FROM openjdk:8-jre-alpineMAINTAINER JiangYuRU…

米尔电子Zynq UltraScale MPSoC核心板资料介绍

米尔Zynq UltraScale MPSoC核心板&#xff08;MYC-CZU3EG&#xff09;是采用Xilinx新一代Zynq处理器。该核心板是业界最小尺寸Zynq UltraScale 核心板&#xff0c;采用16纳米制程&#xff0c;相比Znyq7000系列每瓦性能提升5倍&#xff0c;且单芯片融合4核心Cortex-A53&#xff…

幸福秘诀 男女必须要看哦

女人说&#xff1a;这一辈子最大的成功是什么?我认为是找到一个真正疼自己的老公,有了老公的支持才可以把事业做得有声有色,有一个幸福的家和一个可爱的宝宝。 男人说&#xff1a;我的成功是在我的人生之中&#xff0c;是妻子和我形影相随&#xff0c;朝夕相伴。她是我身边…