我有一个方法为this.move的AgentClass。它正在使用静态对象,但是当我通过.append()创建新的HTML对象时,我无法将它们与this.move方法一起使用。
所有新对象都有一个 ID,我想使用 move 方法对它们进行动画处理。
我经常读到"生活,在,..."但他们都需要一个活动...我没有这样的事件。他们直接移动。我尝试了类似的东西:
$('.agents').on("load", Agent.move());
但这行不通...有什么想法吗?
Codesinppet:
var Agent = function(agentType, xTarget, yTarget) {
...
this.move = function() {
var id = this.agentId;
$('.agent#'+id).animate({
left:"200px"
}, 1000);
}
}
我像这样附加它们之后:
for (deployed = 0; deployed <= agents; deployed++) {
$('.agents').append('<div class="agent" id="'+deployed+'"></div>');
}
如果有人能帮助我,那就太棒了!?
您可以使用 .clone(true) 一个布尔值,指示是否应将事件处理程序和数据与元素一起复制。默认值为 false。
var agents = 6;
for (deployed = 0; deployed <= agents; deployed++) {
$element = $('<div class="agent" id="'+deployed+'"></div>').clone(true);
$('.agents').append($element);
}
.agent {
height:50px;
width:50px;
background-color:yellow;
margin-bottom:10px
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!DOCTYPE html>
<html>
<head>
<title>Agent</title>
</head>
<body>
<div class="agents">
</div>
</body>
</html>
但是为了获得最大的优化事件,最好使用事件处理程序"on"来监视重新加载 DOM 后将添加的项目。这分配的内存更少