ie使用d3的html方法无效,html - D3 svg chart can't display in IE - Stack Overflow

I'm building a website which contains d3 svg to display the bar chart. It can display in Chrome, Firefox, Edge, Safari, but it is not working in IE. I have tried to use canvas method, but it is not working. Then I tried set viewbox for svg, but it is not working as well. Could anyone help me solve this problem?

Here's my d3.js and html code

function homeStats() {

var jsonobj = document.getElementById('stats-data').value;

var data = JSON.parse(jsonobj);

var parentDiv = document.getElementById("home-stats");

function drawbar() {

var margin = { top: 40, right: 20, bottom: 100, left: 40 };

var width = parentDiv.clientWidth - margin.left - margin.right;

var height = parentDiv.clientHeight - margin.top - margin.bottom;

var tip = d3.tip()

.attr('class', 'd3-tip')

.offset([-10, 0])

.html(function (d) {

return "" + d.value + "";

})

d3.selectAll('#home-stats-svg').remove()

var svg = d3.select("#home-stats").append("svg").attr("id", "home-stats-svg")

.attr("width", width + margin.left + margin.right)

.attr("height", height + margin.top + margin.bottom)

.append("g")

.attr("transform", "translate(" + margin.left + "," + margin.top + ")");

svg.call(tip);

var x0 = d3.scale.ordinal()

.rangeRoundBands([0, width], .65);

var x1 = d3.scale.ordinal();

var y = d3.scale.linear()

.range([height, 0]);

var color = d3.scale.ordinal()

.range(["#f79944", "#20b5e1"]);

var xAxis = d3.svg.axis()

.scale(x0)

.orient("bottom");

var yAxis = d3.svg.axis()

.scale(y)

.orient("left")

var columnNames = d3.keys(data[0]).filter(function (key) { return key !== "Year"; });

data.forEach(function (d) {

d.subGroups = columnNames.map(function (name) { return { name: name, value: +d[name] }; });

});

x0.domain(data.map(function (d) { return d.Year; }));

x1.domain(columnNames).rangeRoundBands([0, 30]);

y.domain([0, d3.max(data, function (d) { return d3.max(d.subGroups, function (d) { return d.value; }); })]);

svg.append("g")

.attr("class", "x axis")

.attr("transform", "translate(0," + height + ")")

.call(xAxis);

svg.append("g")

.attr("class", "y axis")

.call(yAxis)

.append("text")

.attr("transform", "rotate(-90)")

.attr("y", 6)

.attr("dy", ".71em")

.style("text-anchor", "end");

const rx = 5;

const ry = 5;

var Year = svg.selectAll(".Year")

.data(data)

.enter().append("g")

.attr("class", "Year")

.attr("transform", function (d) { return "translate(" + x0(d.Year) + ",0)"; });

Year.selectAll("rect")

.data(function (d) { return d.subGroups; })

.enter().append("path")

.style("fill", function (d) { return color(d.name); })

.attr("d", item => `

M${x1(item.name)},${y(item.value) + ry}

a${rx},${ry} 0 0 1 ${rx},${-ry}

h${10 - 2 * rx}

a${rx},${ry} 0 0 1 ${rx},${ry}

v${height - y(item.value) - ry}

h${-(10)}Z

`)

.on('mouseover', tip.show)

.on('mouseout', tip.hide);

var legend = svg.selectAll(".legend")

.data(columnNames.slice().reverse())

.enter().append("g")

.attr("class", "legend")

.attr("transform", function (d, i) { return "translate(0," + i * 20 + ")"; });

legend.append("rect")

.attr("x", width - 5)

.attr("width", "1vw")

.attr("height", "2vh")

.style("fill", color);

legend.append("text")

.attr("x", width - 7)

.attr("y", 9)

.attr("dy", ".35em")

.style("text-anchor", "end")

.text(function (d) { return d; });

}

drawbar();

}

Html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值