ie下设置样式时参数值的坑,解决流程梳理

  起因是项目中饼图如果分区太多,文字显示不下,于是我做了一版将文字使用牵引线放到饼图周围的样式。

  做完后 chrome 没问题。。。后来测试过程中(使用ie9),发现饼图绘制不出来,打开f12查看控制台,发现有个错误:对象不支持 apply 属性或方法。也点不进去,这怎么办呢?启动ie自带的浏览器调试功能吧,错误的时候停下了,报错说是 js 文件的多少行有这个问题,开 chrome 找到那一行,发现是个 console.error.apply() 的错误。

  难道是 console 对象没引进来?百度了下解决 console 没有 apply 的解决办法,然而失败了。

  没查到 console apply 的解决办法,决定换条路试试,通过对比以前的历史记录,确定了是我后加的牵引线及文字部分代码的问题,因为切换回去后是可用的。

  将一些没用的动效移除,只剩下写添加元素、js计算值、添加样式的干货,再次查看 ie ,还是不行,不过报错的问题提示换了:参数无效。

  参数无效!这是一个好提示,再看svg的画图步骤,牵引线出来了,而文字没出来,可以一步一步注释看到底是哪个样式设置错了。

//添加弧外的文字元素
arcs.append("text")
    .attr("transform", function (d) {
        var x = 0;
        var y = 0;
        x = (d.textLine.x1 + d.textLine.x2) / 2;
        y = d.textLine.y1 - fontsize * 0.4;
        return "translate(" + x + "," + y + ")";
     })
     .style("text-anchor", "middle")
     .style("font-size", fontsize)
     .text(function (d) {
         return getDisplayChars(d.data.displayName, 20);
     });

  能猜出来问题可能出现在哪里不?

  font-size!为了方便计算, fontsize 变量保存的值是 number 类型的,chrome 下没毛病,它兼容这种数值设置。但 ie 下就有问题了!只能进行设置带 “px” 的值,于是乎在设置font-size 的时候,在 fontsize 后加上   +"px"   就解决问题了。好大一个坑!不过这次会永久的记住!

原文地址:https://www.cnblogs.com/guofan/p/7834055.html