我foreignObject
在 SVG 中苦苦挣扎。我想在 a 中添加文本rect
,并获得自动文本换行,我选择使用 HTML。的描述foreignObject
可以在这里找到。
我正在使用 D3,这是我的数据:
var cds = [
{"uid":"U12","sid":"16","statement":"Movies","x":10,"y":10},
{"uid":"U20","sid":"17","statement":"Food","x":10,"y":170},
{"uid":"U22","sid":"15","statement":"Sport","x":10,"y":330}
];
我为每个数据添加一张卡片,并希望显示数据中的“声明”。
var cardsize = { width : 150, height : 150 };
var svg = d3.select("body").append("svg:svg")
.attr("width", 170)
.attr("height", 490);
var card = svg.selectAll("rect")
.data(cds)
.enter().append("svg:g")
.attr("class", "card")
.attr("transform", function(d,i) {
d.x = 10;
d.y = 10+i*(10+cardsize.height);
return "translate(" + d.x + "," + d.y + ")";
});
card.append("svg:rect")
.attr('width', cardsize.width)
.attr('height', cardsize.height)
card.append("svg:foreignObject")
.attr('width', cardsize.width)
.attr('height', cardsize.height)
.append('p')
.attr("class","statement")
.text(function(d) { return d.statement; });
一张卡片的输出是这样的:
<g class="card" transform="translate(10,330)">
<rect width="150" height="150"></rect>
<foreignObject width="150" height="150"><
p class="statement">Sport</p>
</foreignObject>
</g>
我在测试过的 (mac) 浏览器(Safari 6.0.2、Chrome 25.0.1364.99、Firefox 18.0.2)中看不到文本。W3 的验证器不喜欢输出,并为每张卡给我这个错误:
在此上下文中,元素 foreignObject 不允许作为元素 g 的子级。
所以我的问题是,问题出在哪里,为什么foreignObject 不允许作为元素的子g
元素?
我也想知道为什么.html(function(d) { return d.statement; });
不起作用(没有输出)。但.text(function(d) { return d.statement; });
工作正常吗?
这是一个小提琴。