添加文本到rect不工作

时间:2015-04-07 11:49:35

标签: html d3.js

我正在尝试将文字添加到rect但它似乎没有工作,这就是我正在尝试的,

var width = 600,
height = 600;
var margin = {top: -5, right: -5, bottom: -5, left: -5};

var zoom = d3.behavior.zoom()
    .scaleExtent([1, 15])
    .on("zoom", zoomed);

var svgContainer = d3.select("body").append("svg")
                                    .attr("width", width)
                                    .attr("height", height)
                                    .style("background-color", "black")
                                    .append("g")
                                    .attr("transform", "translate(" + margin.left + "," + margin.right + ")")
                                    .call(zoom);

var zoomed = function () {
    svgContainer.attr("transform", "translate("+ d3.event.translate + ")scale(" + d3.event.scale + ")");
};

var zoom = d3.behavior.zoom()
.scaleExtent([1, 8])
.on("zoom", zoomed)
.size([width, height]);

svgContainer.call(zoom);

var rectangle1 = svgContainer.append("rect")
                            .attr("x", 0)
                            .attr("y", 0)
                            .attr("width", 100)
                            .attr("height", 100)
                            .attr("fill", "red")
                            .append("text")
                            .text("Hahaha");

这里的小提琴 - http://jsfiddle.net/nhe613kt/60/

1 个答案:

答案 0 :(得分:1)

rect不能包含文本元素。而是使用文本和矩形的位置转换g元素,然后将矩形和文本追加到它:

D3 Appending Text to a SVG Rectangle

svgContainer.append("text")
    .attr("id", "rectangleText")
    .attr("class", "visible")
    .attr("x", 10)
    .attr("y", 50)
    .attr("dy", ".35em")
.text("You're Welcome :)");

不是将其附加到矩形而是将其附加到对象上,矩形将附加到:)

小提琴:http://jsfiddle.net/nhe613kt/71/

另外,拖动矩形有点静,不能正确移动。您需要分割缩放功能并单独创建拖动功能。然后将拖动追加到矩形,并缩放到SVG :)

希望有所帮助