如何将变量传递给jquery动画函数属性?
function SlideObject(Side) { $("#div").animate({ margin+Side: "-1000px", opacity: "hide" }, 1000); }
我想将“Side”的值传递给animate函数的属性标识符(margin)的名称。
我知道“margin + Side”无效,只是作为占位符。 例如,如果我手动指定属性名称,则可以使用“marginLeft”来命名一个示例。 我想提供“Left”,“Right”,“Top”或“Bottom”作为SlideObject函数的参数。
我在做这件事时遇到了麻烦,一个例子会很精彩。
谢谢
首先, 不要使用eval()
来执行此操作。 如果您以任何方式使用用户输入作为其中一部分(直接或间接),则没有必要并且会使您的站点暴露于漏洞。 正确的方法是:
This is a test
使用CSS:
#div { padding: 15px; background: yellow; }
和Javascript:
function slideObject(side) { var anim = {opacity: 0}; anim["margin" + side] = "-1000px"; $("#div").animate(anim, 1000); } $(function() { slideObject("Left"); });
您会注意到opacity
值更改为0. hide
不是opacity
的有效值。
基本上,您创建匿名对象,然后使用[]
分配动态属性。