我有一个强制导向图,我想在鼠标上更改节点中的文本.我试图通过在数据数组中放置“full_name”数据然后在鼠标悬停时调用它,就像我调用它来获取蓝色矩形图像一样.但它似乎不起作用,我没有得到任何错误.所以我不知道是什么问题..

您可以在此处查看和编辑示例:http://jsfiddle.net/dzorz/CqaLh/

和脚本看起来像这样:

var data = {"nodes":[
                        {"name":"Action 1","type":2,"slug": "","entity":"employee" },{"name":"Action 2","type":3,{"name":"Action 4","type":5,"value":265000,"entity":"employee"},{"name":"Action 5","type":6,"value":23000,{"name":"Action 3","type":4,"value":115000,{"name":"YHO","full_name":"Yahoo","type":1,"slug": "www.yahoo.com","entity":"company","img_hrefD":"http://img4host.net/upload/30143226522090da3be7a.jpg","img_hrefL":"http://img4host.net/upload/30145118522095467b7e3.jpg"},{"name":"GGL","full_name":"Google","slug": "www.google.com","img_hrefL":"http://img4host.net/upload/30145118522095467b7e3.jpg" },{"name":"BNG","full_name":"Bing","slug": "www.bing.com",{"name":"YDX","full_name":"Yandex","img_hrefL":"http://img4host.net/upload/30145118522095467b7e3.jpg" }
                    ],"links":[
                        {"source":0,"target":3,"value":10},{"source":4,"value":1},{"source":1,"target":7,{"source":2,"target":4,"target":5,"target":6,{"source":8,"value":1}
                        ]
               }    



    var w = 560,h = 500,radius = d3.scale.log().domain([0,312000]).range(["10","50"]);

    var vis = d3.select("body").append("svg:svg")
        .attr("width",w)
        .attr("height",h);

        vis.append("defs").append("marker")
        .attr("id","arrowhead")
        .attr("refX",25 + 3) /*must be smarter way to calculate shift*/
        .attr("refY",2)
        .attr("markerWidth",6)
        .attr("markerHeight",4)
        .attr("orient","auto")
        .append("path")
            .attr("d","M 0,0 V 4 L6,2 Z"); //this is actual shape for arrowhead

    //d3.json(data,function(json) {
        var force = self.force = d3.layout.force()
            .nodes(data.nodes)
            .links(data.links)
            .distance(150)
            .charge(-1000)
            .size([w,h])
            .start();



        var link = vis.selectAll("line.link")
            .data(data.links)
            .enter().append("svg:line")
            .attr("class",function (d) { return "link" + d.value +""; })
            .attr("x1",function(d) { return d.source.x; })
            .attr("y1",function(d) { return d.source.y; })
            .attr("x2",function(d) { return d.target.x; })
            .attr("y2",function(d) { return d.target.y; })
            .attr("marker-end",function(d) {
                                                if (d.value == 1) {return "url(#arrowhead)"}
                                                else    { return " " }
                                            ;});


        function openLink() {
            return function(d) {
                var url = "";
                if(d.slug != "") {
                    url = d.slug
                } //else if(d.type == 2) {
                    //url = "clients/" + d.slug
                //} else if(d.type == 3) {
                    //url = "agencies/" + d.slug
                //}
                window.open("//"+url)
            }
        }




        var node = vis.selectAll("g.node")
            .data(data.nodes)
          .enter().append("svg:g")
            .attr("class","node")
            .call(force.drag);


        node.append("circle")
            .attr("class",function(d){ return "node type"+d.type})
            .attr("r",function(d) { return radius(d.value) || 10 })
            //.style("fill",function(d) { return fill(d.type); })


        node.append("svg:image")
            .attr("class",function(d){ return "circle img_"+d.name })
            .attr("xlink:href",function(d){ return d.img_hrefD})
            .attr("x","-36px")
            .attr("y","-36px")
            .attr("width","70px")
            .attr("height","70px")
            .on("click",openLink())
            .on("mouSEOver",function (d) { if(d.entity == "company")
                                                {
                    d3.select(this).attr("width","90px")
                                    .attr("x","-46px")
                                    .attr("y","-36.5px")
                                   .attr("xlink:href",function(d){ return d.img_hrefL});

                                                }
                })
            .on("mouSEOut",function (d) { if(d.entity == "company")
                                            {
                    d3.select(this).attr("width","70px")
                                    .attr("x","-36px")
                                    .attr("y","-36px")
                                   .attr("xlink:href",function(d){ return d.img_hrefD});
                                            }
                });    


        node.append("svg:text")
            .attr("class",function(d){ return "nodetext title_"+d.name })
            .attr("dx",0)
            .attr("dy",".35em")
            .attr("text-anchor","middle")
            .style("fill","white")
            .text(function(d) { return d.name })
            .on("mouSEOver",function (d) { if(d.entity == "company"){
                    d3.select(this).text(function(d) { return d.full_name })

                }
            });

        force.on("tick",function() {
          link.attr("x1",function(d) { return d.source.x; })
              .attr("y1",function(d) { return d.source.y; })
              .attr("x2",function(d) { return d.target.x; })
              .attr("y2",function(d) { return d.target.y; });

          node.attr("transform",function(d) { return "translate(" + d.x + "," + d.y + ")"; });
        });
    //});

CSS:

@charset "utf-8";
/* CSS Document */

.link10 { stroke: #ccc; stroke-width: 3px; stroke-dasharray: 3,3; }
.link1 { stroke: #000; stroke-width: 3px;}
.nodetext { pointer-events: none; font: 14px sans-serif; font-weight:bold;}

.node.type1 {
  fill:brown;
}
.node.type2 {
  fill:#337147;
}
.node.type3 {
  fill:blue;
}
.node.type4 {
  fill:red;
}

.node.type5 {
    fill:#1BC9E0;
}

.node.type6 {
    fill:#E01B98;
}

image.circle {
    cursor:pointer;
}

.fadein{
display:none;
font-size:20px;
}

.rectD{
background-color:#000000;
width:70px;
height:30px
}

.rectL{
background-color:#000000;
width:90px;
height:30px
}

甚至可以在加载所有内容后更改文本?

请帮忙

解决方法

每个节点都有一个图像和一个与之关联的文本元素.图像和文本元素的鼠标悬停事件彼此干扰,因为它们占据相同的空间.

我分叉了你的jsfiddle并为节点创建了一个鼠标悬停监听器并将两个事件放在同一个函数中:

node.on("mouSEOver",function (d) {
            d3.select(this).select('text')
                .text(function(d){
                    return d.full_name;
                })
            if (d.entity == "company") {
                d3.select(this).select('image')
                    .attr("width","90px")
                    .attr("x","-46px")
                    .attr("y","-36.5px")
                    .attr("xlink:href",function (d) {
                        return d.img_hrefL
                    });               
            }
        });

(节点上有一个类似的监听器,用于鼠标输出以反转这些变化).

javascript – D3.js在鼠标悬停时更改文本,是否可能?的更多相关文章

  1. Html5 滚动穿透的方法

    这篇文章主要介绍了Html5 滚动穿透的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. HTML5 拖放(Drag 和 Drop)详解与实例代码

    本篇文章主要介绍了HTML5 拖放(Drag 和 Drop)详解与实例代码,具有一定的参考价值,有兴趣的可以了解一下

  3. 跨域修改iframe页面内容详解

    这篇文章主要介绍了跨域修改iframe页面内容详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  4. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  5. ios – 暂停调度队列是否会暂停其目标队列?

    我想创建两个串行队列A&B.队列B是队列A的目标.我想在B上排队一些块,并暂停它直到我准备执行它们,但是我想继续在队列A上执行块.如果我暂停B,这还会暂停它的目标队列(队列A)吗?我的想法是,我想安排这些特定的块在稍后日期执行但是我不希望它们同时运行而我不这样做想要处理信号量.但我希望队列A继续处理它的块,而B则被暂停如果不清楚这里是一些示例代码解决方法queueB被挂起,但queueA未被挂起.queueA和queueB被挂起.

  6. ios – 使用CocoaPods post install hook将自定义路径添加到HEADER_SEARCH_PATHS

    解决方法在Podfile中定义一个方法:然后在post_install中调用该方法:

  7. ios – 在Swift中删除WKWebView Accesory栏

    我现在正试着将this转换成Swift而没有真正的背景.这是我到目前为止所得到的…而且我一直在寻找谷歌并不知道要搜索什么才能更具体.你能否详细说明我做错了什么?

  8. iOS,ld:framework没有找到适用于架构arm64的GoogleMaps

    Podfile看起来像这个Cocoapodsv1.0beta6):解决方法更新请检查您是否在架构中具有相同的构建设置,并仅构建活动体系结构中的目标键你的podfile应该是这样的在您启动ProjectTest目标之前结束项目目标,也是为什么添加继承!

  9. ios – 为CocoaPods的pod设置部署目标

    我使用CocoaPods来管理项目中的依赖关系.我写了Podfile:此文件与CocoaPods0.x配合使用,但在我更新到CocoaPods1.0之后,我无法编译项目.运行后我无法编译我的项目错误:/Users/

  10. ios – 如何在故事板上单击UIImageView(swift)

    我是新来的,我想知道如何在故事板上单击ImageView.我想要做的是使其点击时,它显示另一个视图控制器.解决方法您可以添加tapGesture.这是代码:Swift3.0

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部