JQuery3.0 抛出错误设置只有 getter firefox 的属性

2023-12-10

我动态创建了 SVG 圆圈,并使用 JQuery 将其小圆圈动画化为大圆圈。动画在其他 JQuery 版本中工作正常并抛出异常“设置一个只有 getter 的属性”仅适用于 JQuery 3.0 版本。我在网上搜了一下。这是由于属性没有setter函数造成的。

_animateCircle: function (element, delayInterval) {
            var radius = element.getAttribute("r");
            var scaleVal;
            var $ele = $(element);
            var layer = this;
            $ele.delay(delayInterval).each(function () { }).animate(
                {   
                    r: radius // if i comment this line, exception not occur. But animation not working
                },
                {
                    duration: 700,

                    step: function (now) {
                        scaleVal = now;
                    }
                }
            );
        }

我的问题是为什么这仅在 JQuery 3.0 版本中不起作用。请就此向我提出建议。

谢谢, 巴拉蒂。


编辑、更新

Firefox 最后记录错误的解决方法else at Tween.propHooks._default.set line 6571

else {
      tween.elem[ tween.prop ] = tween.now; // logs error
}

您可以创建一个属性值等于的对象r值,这是一个SVGAnimatedLength对象以及在动画应停止处具有值的属性;在step的函数.animate()调用创建的对象作为参数jQuery()设置属性使用.attr("r", now),它似乎在 Firefox、Chromium 上返回相同的结果

var fx = {
  _animateCircle: function(element, delayInterval) {
    var r = element.attr("r");
    var radius = {from:r, to:r * 2}; // set `r` to `radius.to` value
    $(radius).delay(delayInterval).animate({
      from: radius.to
    }, {
      duration: 700,
      step: function(now) {
        element.attr("r", now);
      }
    });
  }
}

fx._animateCircle($("circle"), 500)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <circle cx="200" cy="100" r="50" stroke-width="1" fill="blue" />
</svg>

jsfiddlehttps://jsfiddle.net/bxmgqnq3/3/


代替$.fn.attr() for .getAttribute()

var fx = {
  _animateCircle: function(element, delayInterval) {
    var radius = element.attr("r") * 2;
    console.log(radius);
    var scaleVal;
    element.delay(delayInterval).animate({
      r: radius
    }, {
      duration: 700,
      step: function(now) {
        scaleVal = now;
      }
    });
  }
}

fx._animateCircle($("circle"), 500)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
  <circle cx="200" cy="100" r="50" stroke-width="1" fill="blue" />
</svg>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JQuery3.0 抛出错误设置只有 getter firefox 的属性 的相关文章

随机推荐

  • 如何使用 REST 将数据从 AngularJS 发布到 Struts 2

    我需要从客户端获取到服务器端的值 我正在使用 AngularJS 和 Struts2 REST 我的控制器没有获取传递的值 还是我传递或使用 RESTful 控制器时出错了 这是我的代码 angularcontroller js app c
  • Android Studio 意外的顶级异常:

    今天 我遇到了一个巨大的错误 不允许我在手机上运行示例项目 当 Android Studio 构建项目时 它首先显示以下目标 UP TO DATE demoproject processDebugResources UP TO DATE d
  • 如何获取java中两个日期之间的日期列表?如何还包含/排除开始日期/结束日期?

    我已经尝试过堆栈溢出中给出的示例java中如何获取两个日期之间的日期列表 该代码完美运行 但有一个小问题 我的列表中也没有得到结束日期 如何选择包含 排除开始日期并包含结束日期 我可以使用remove 和add 手动执行此操作吗 或者Jod
  • 将 checkstyle-configuration 从声纳导入到 eclipse-checkstyle-plugin

    我想从声纳导出 checkstyle 规则并将它们导入到 checkstyle eclipse 插件中 不幸的是 sonar 将 checkstyle 规则导出到 csv 文件 但 checkstyle 插件只接受 xml 文件的导入 有什
  • SignalR 2.2 和 ARR3.0 负载平衡

    我正在使用 signalr2 2 Web 应用程序并托管在 IIS 8 中 这里我尝试使用ARR3 0为我的应用程序实现负载均衡 在我的服务器场中 我连接了两台服务器并将路由规则设置为 加权循环 每个服务器都有一个带有 HTML 页面的 j
  • 如何将文本文件从 jar 复制到 jar 外部的文件中?

    假设我的 jar 包 com test io 中有一个名为 test txt 的文件 我将如何编写一个类来检索该文本文件 然后将内容复制到文件系统上的新文件中 假设所述 jar 在您的类路径上 URL url getClassLoader
  • 我找不到 Android keytool

    我正在尝试遵循 Android 映射教程并且到了这部分我必须获得 API 密钥 我已经找到了我的debug keystore但似乎没有keytool应用程序在目录中 C Documents and Settings tward androi
  • Range(Cells()) 中的运行时错误 1004

    我在许多宏中有以下代码 但它需要大量我不需要的信息 公式如下 Range A1 h BD h Value Worksheets ABC1 Range A h BD h Value 我尝试将公式更改为更动态的版本 如下 Sub MFGI NA
  • 将 P 值添加到组内比较箱线图

    我正在尝试创建一个箱线图 它仅显示箱线图中每个条形的组内的显着 p 值 例如 它会比较 I1 和 SI2 的 一般 良好 非常好 等 我尝试使用以下代码来实现上面的情节 library ggplot2 library dplyr data
  • 三元运算符与 if 语句的优点

    我正在浏览一些代码 发现其中有一些三元运算符 这段代码是我们使用的一个库 它应该非常快 我在想除了空间之外我们是否还可以节省任何东西 你的经验是什么 表现 三元运算符的性能与编写良好的等效运算符不应有差异if else声明 它们很可能解析为
  • Android Studio 通知管理器错误

    我编写了一段代码 以便在信标范围内时弹出通知 我的通知代码如下 private void showNotification String message Log d Hay8 DCM8 Intent intent new Intent co
  • _Generic 宏中传递的指针类型不兼容

    以下代码生成 2 个警告 如问题标题中所述 include
  • 将 SceneKit 场景导出为 Collada .dae 文件的最简单方法?

    我有一个算法生成的 SceneKit 场景 我希望能够将其导出为 Collada dae 文件 例如用于 iBooks Author 中 由于 SceneKit 可以导入 Collada 文件 我认为也可能有办法导出它们 但在 API 中找
  • 使用 HttpClient 在“适配器已分离”和“无包装连接”之间切换

    所以正如我所说 当我尝试运行时 我在这两个错误之间来回跳动HttpClient execute HttpPost 得到IllegalStateException public class NetMethods private static
  • 更改占位符一部分的颜色[重复]

    这个问题在这里已经有答案了 如何只更改占位符的一部分 这是我的html div class col md 4 p class form row form row wide p div
  • actionbarsherlock 使用选项卡导航 选项卡导航

    我有一个后期需求更改 需要选项卡导航 我已经在我的应用程序中使用了 ActionBarSherlock 以前我的用户界面由活动组成 但是 据我了解 TabBar 需要片段活动吗 我有什么办法可以保留现有代码并实现 TabBar 或者这需要完
  • 使用原型继承重写方法

    我正在使用这个克隆方法进行原型继承专业 JavaScript 设计模式这基本上是相同的Crockford 的 object 函数 唯一的区别是 Crockford 添加了调用括号 但由于 F 为空 我不确定这是否重要 我认为这不是问题 cl
  • Delphi TBitmap - 为什么 Pixels 和 ScanLine 不同?

    在使用 32 位 TBitmap 时 我从 Canvas Pixels 切换到 ScanLine 然后我将值设置为红色 却发现它显示为蓝色 知道为什么吗 这是代码摘录 procedure TForm1 FormPaint Sender TO
  • 在 Android KitKat 上隐藏导航栏后显示导航栏

    在我的应用程序中 我想让用户隐藏或显示导航栏 后退 主页 菜单 系统栏 电池 wifi 通知 应始终隐藏 我用以下代码隐藏系统栏 getWindow setFlags WindowManager LayoutParams FLAG FULL
  • JQuery3.0 抛出错误设置只有 getter firefox 的属性

    我动态创建了 SVG 圆圈 并使用 JQuery 将其小圆圈动画化为大圆圈 动画在其他 JQuery 版本中工作正常并抛出异常 设置一个只有 getter 的属性 仅适用于 JQuery 3 0 版本 我在网上搜了一下 这是由于属性没有se