javascript - foreignObject 中的背景图像隐藏了 Firefox 上的其他 svg 元素

标签 javascript html css d3.js svg

我在向使用 d3 创建的可视化效果添加横幅时遇到问题。我想添加横幅,然后在横幅顶部添加文本。这在 Chrome 上有效(文本呈现在图像的“顶部”),但在 Firefox 上,图像看起来像是呈现在文本的顶部。有人知道为什么这在 Chrome 中有效,但在 Firefox 中无效,有没有办法可以在 Firefox 中实现相同的结果?

    var margin = {
    top: 155,
    right: 3,
    bottom: 3,
    left: 3
  },
  width = $(window).width() - margin.left - margin.right,
  height = $(window).height() - margin.top - margin.bottom,
  formatNumber = d3.format(",d"),
  transitioning;

var x = d3.scale.linear()
  .domain([0, width])
  .range([0, width]);

var y = d3.scale.linear()
  .domain([0, height])
  .range([0, height]);

var svg = d3.select("body").append("svg")
  .attr("width", width + margin.left + margin.right)
  .attr("height", height + margin.top + margin.bottom)
  .append("g")
  .attr("transform", "translate(" + margin.left + "," + margin.top + ")")
  .style("shape-rendering", "crispEdges");

var grandparent = svg.append("g").attr("class", "grandparent");

grandparent.append("rect")
  .attr("y", -margin.top)
  .attr("width", width)
  .attr("height", margin.top);

grandparent.append("foreignObject")
.attr("y", -margin.top)
  .attr("width", width)
  .attr("height", margin.top)
  .append("xhtml:div")
  .attr("class", "bannerDiv");

grandparent.append("text")
  .attr("x", 6)
  .attr("y", (-1 / 8) * margin.top)
  .attr("dy", ".75em")
  .style("fill", "#A5D867")
  .text("The text here");

function text(text) {
  text.attr("x", function(d) {
      return x(d.x) + 6;
    })
    .attr("y", function(d) {
      return y(d.y) + 6;
    });
}

请参阅此 jsfiddle 示例: https://jsfiddle.net/rmw6snj6/

最佳答案

这是 Firefox 中的一个已知错误:https://bugzilla.mozilla.org/show_bug.cgi?id=984312

在错误报告中,一种给定的解决方法是将 foreignObject 的转换设置为 translate(0,0)

input:checked + svg foreignObject {
  transform: translate(0, 0);
}
.bannerDiv {
  width: 100%;
  height: 100%;
  background-image: url('http://www.newdesignfile.com/postpic/2011/10/header-banner-design_64599.jpg');
  -webkit-background-size: 100% 100%;
  -moz-background-size: 100% 100%;
  -o-background-size: 100% 100%;
  background-size: 100% 100%;
}

body {
  background: #bbb;
}
<label>workaround</label><input type="checkbox" checked/>
<svg width="535" height="484">
  <g transform="translate(3,155)" style="shape-rendering: crispedges;">
    <g class="grandparent">
      <rect y="-155" width="529" height="155"></rect>
      <foreignObject y="-155" width="529" height="155">
        <div class="bannerDiv"></div>
      </foreignObject>
      <text x="6" y="-19.375" dy=".75em" style="fill: rgb(165, 216, 103);">The text here</text>
    </g>
  </g>
</svg>

关于javascript - foreignObject 中的背景图像隐藏了 Firefox 上的其他 svg 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46085953/

相关文章:

javascript - 使用命名函数来捕获 promise 中的错误?

javascript - 解构数组时如何忽略项目?

html - 在 node.js 代码中渲染一个完整的网页

html - CSS 悬停在图像上,即使它不包含在内

javascript - 如何在不调整大小的情况下更改输入的字体?

JavaScript - 替换为英文数字

JavaScript import() 和export() 函数用法

php、mysql、jquery、表单元素链选择

javascript - Checkbox和onchange方法使用

c# - 如何在 c# wpf 的 webbrowser 控件中从动态创建的网页引用 css 样式表?