SVG矩形边框,不是笔画

时间:2014-07-23 14:43:31

标签: javascript html css svg d3.js

我正在创建一个d3图并尝试在我的rect元素周围添加边框。 rect元素附加到单元格,文本元素附加到同一单元格。因此,如果我在矩形中更改笔划,我会因某种原因丢失所有文本,如果我更改单元格中的笔划,边框和字体也会改变。

这是我绘制图表的代码的一部分。

this.svg = d3.select("#body").append("div")

          .attr("class", "chart")
          .style("position", "relative")
          .style("width", (this.w +this.marginTree.left+this.marginTree.right) + "px")
          .style("height", (this.h + this.marginTree.top + this.marginTree.bottom) + "px")
          .style("left", this.marginTree.left +"px")
          .style("top", this.marginTree.top + "px")
        .append("svg:svg")
          .attr("width", this.w)
          .attr("height", this.h)
        .append("svg:g")
          .attr("transform", "translate(.5,.5)");


        this.node = this.root = this.nestedJson;



        var nodes = this.treemap.nodes(this.root)
            .filter(function(d) { return !d.children; });

        this.tip = d3.tip()
              .attr('class', 'd3-tip')
              .html(function(d) {
                return "<span style='color:white'>" + (d.name+",\n "+d.size) + "</span>";
              })
        this.svg.call(this.tip);



        var cell = this.svg.selectAll("g")
            .data(nodes)
            .enter().append("svg:g")
            .attr("class", "cell")
            .call(this.position)
            .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; })
            .on("click", function(d) { return this.zoom(this.node == d.parent ? this.root : d.parent); })
            .style("border",'black');

        var borderPath = this.svg.append("rect")
            .attr("x", this.marginTree.left)
            .attr("y", this.marginTree.top)
            .attr("height", this.h - this.marginTree.top - this.marginTree.bottom )
            .attr("width", this.w - this.marginTree.left - this.marginTree.right)
            .style("stroke", 'darkgrey')
            .style("fill", "none")
            .style("stroke-width", '3px');


        cell.append("svg:rect")

            .attr("id", function(d,i) { return "rect-" + (i+1); })
            .attr("class","highlighting2")
                .attr("title", function(d) {return (d.name+", "+d.size);})
                .attr("data-original-title", function(d) {return (d.name+",\n "+d.size);})
          .attr("width", function(d) { return d.dx - 1; })
          .attr("height", function(d) { return d.dy ; })
          .on('mouseover', this.tip.show)
                .on('mouseout', this.tip.hide)
          .style("fill", function(d) {return coloring(d.color);});


        cell.append("svg:text")
            .attr("class", "treemap-text nameTexts") 
            .attr("id", function(d,i) { return "name-" + (i+1); })
            .attr("x", cellMargin)  
            .attr("y", function(d) {  return parseInt($('.treemap-text').css('font-size'))+cellMargin; })
          .text(function(d) {return (d.name);});

       cell.append("svg:text")
            .attr("class", "treemap-text sizeTexts") 
            .attr("id", function(d,i) { return "size-" + (i+1); })  
            .attr("x", cellMargin)  
            .attr("y", function(d) {  return 2*parseInt($('.treemap-text').css('font-size'))+2*cellMargin; })
            .text(function(d) {return (d.size);});

此外,我考虑过创建线条并在每个rect元素周围绘制四条线,但是想知道是否有更简单的方法。感谢。

1 个答案:

答案 0 :(得分:1)

我没有通过您的来源完全检查,使用jsbin,codepen,jsfiddle或其他在线平台来显示您的问题也会有所帮助。

实际上我认为你只是误解了SVG演示属性及其CSS样式。对于SVG元素,只有SVG表示属性在CSS中有效。这意味着您的代码中没有border属性。另请注意,对于<text>元素,填充颜色是字体颜色,笔划是字体的轮廓。考虑到笔画和填充是继承到子元素,这意味着如果你有一个带有笔触样式的矩形和一些包含文本元素的矩形,它们将笔划应用为轮廓,你需要覆盖那里的样式。

希望你能解决你的问题。

干杯 只园