zoukankan      html  css  js  c++  java
  • 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"   就解决问题了。好大一个坑!不过这次会永久的记住!

  • 相关阅读:
    [loj2706]文本编辑器
    [atAGC053C]Random Card Game
    [atAGC056E]Cheese
    [cf1615G]Maximum Adjacent Pairs
    [cf739D]Recover a functional graph
    [uoj693]地铁规划
    [atAGC053E]More Peaks More Fun
    [atAGC056B]Range Argmax
    [atAGC056F]Degree Sequence in DFS Order
    SceneGrabber NET 视频批量自动截图软件使用技巧
  • 原文地址:https://www.cnblogs.com/guofan/p/7834055.html
Copyright © 2011-2022 走看看