Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/87.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 独立设置重用svg的动画_Javascript_Html_Css_Svg - Fatal编程技术网

Javascript 独立设置重用svg的动画

Javascript 独立设置重用svg的动画,javascript,html,css,svg,Javascript,Html,Css,Svg,我想一些SVG的动画点击。SVG只定义了一次,并使用标记多次重复使用。 我编写了以下代码: svg{ 边框:1px实心#0af; 笔画:黑色; } 您的问题是ID重复 创建一个Web组件(在所有现代浏览器中都受支持),一旦定义了SVG,它就会注入 <svg-tick id=ONE stroke="red"></svg-tick> <svg-tick id=TWO></svg-tick> <svg-tick id=THRE

我想一些SVG的动画点击。SVG只定义了一次,并使用
标记多次重复使用。 我编写了以下代码:

svg{
边框:1px实心#0af;
笔画:黑色;
}

您的问题是ID重复

创建一个Web组件(在所有现代浏览器中都受支持),一旦定义了SVG,它就会注入

<svg-tick id=ONE stroke="red"></svg-tick>
<svg-tick id=TWO></svg-tick>
<svg-tick id=THREE></svg-tick>
<svg-tick id=FOUR stroke="blue"></svg-tick>

您的问题是重复ID

创建一个Web组件(在所有现代浏览器中都受支持),一旦定义了SVG,它就会注入

<svg-tick id=ONE stroke="red"></svg-tick>
<svg-tick id=TWO></svg-tick>
<svg-tick id=THREE></svg-tick>
<svg-tick id=FOUR stroke="blue"></svg-tick>

您可以将您的
svg
放入一个文件中,并在文档树中访问它,如下所示:

<object data="tick.svg"></object>

您可以将您的
svg
放入一个文件中,并在文档树中访问它,如下所示:

<object data="tick.svg"></object>


多次嵌入完整的SVG有什么不对,特别是考虑到这样做的方式?在Firefox中运行良好,可能是一些Chrome错误。如果不想复制svg,可以尝试使用一些svg动画库。我在所有主流浏览器中都尝试过,其中只有Firefox独立播放动画。据我所知,Firefox实现它的方式与标准不同。@winns否,Firefox被破坏了。:在引用图形中的元素上定义的任何事件侦听器也必须在同一捕获阶段在use元素阴影树中该元素的每个实例上侦听同一事件。。。。。用户代理必须确保每个元素实例的事件侦听器列表同步,以匹配其对应的元素。多次嵌入完整的SVG有什么错,特别是考虑到这样做的方式?在Firefox中工作正常,可能是一些Chrome错误。如果不想复制svg,可以尝试使用一些svg动画库。我在所有主流浏览器中都尝试过,其中只有Firefox独立播放动画。据我所知,Firefox实现它的方式与标准不同。@winns否,Firefox被破坏了。:在引用图形中的元素上定义的任何事件侦听器也必须在同一捕获阶段在use元素阴影树中该元素的每个实例上侦听同一事件。。。。。用户代理必须确保每个元素实例的事件侦听器列表是同步的,以匹配其相应的元素。非常感谢!自定义web组件方法是实现这一点的好方法。没有黑客入侵,也更跨浏览器。对于您的信息,您不一定需要唯一的ID。您可以在自定义组件内的阴影树下添加所有内容,并且不会发生冲突。确实,阴影DOM会解除封装,但全局CSS将不再应用,除非您选择CSS属性::部分等。非常感谢!自定义web组件方法是实现这一点的好方法。没有黑客入侵,也更跨浏览器。对于您的信息,您不一定需要唯一的ID。您可以在自定义组件内的阴影树下添加所有内容,并且不会发生冲突。确实,阴影DOM会解除封装,但全局CSS将不再应用,除非您选择CSS属性、::部分等。