1

我有一个 Javascript 函数,它根据文档中的一些隐藏字段更改某些元素的位置,这些隐藏字段会使用 ajax 定期更新。

问题:

由于javascript函数(onclick)在Ajax(重新加载隐藏字段所在的元素)之前执行,因此应该改变位置的元素总是落后一圈。

我想要达到的目标:

如果在 onclick 事件之前执行 ajax 重新加载,问题将得到解决,因此对隐藏字段的引用将是正确的。(而不是在后面转弯)

这有可能以任何方式还是这个问题有另一种解决方案?

代码:

称呼:

                <h:commandButton id="dice" onclick="animate()" alt="W&uuml;rfel mit einer Eins" image="resources/img/wuerfel1.png" action="#{spiel.dice()}" tabindex="4" title="W&uuml;rfel mit einer Eins">
                    <f:ajax render="gameinfo" />                            
                </h:commandButton>

Javascript函数:

    function animate() {
        var newPlayer1 = document.getElementById('player1score').value;
        var newPlayer2 = document.getElementById('player2score').value;
        // Spieler 1 Animation
        $("#player1").fadeOut(700, function() {
            $("#player1").appendTo(newPlayer1);
            $("#player1").fadeIn(700);
});
        // Spieler2 Animation
        $("#player2").delay(1400).fadeOut(700, function() {
            $("#player2").appendTo(newPlayer2);
            $("#player2").fadeIn(700);
});
    }
4

1 回答 1

2

你应该onevent使用f:ajax

  <h:commandButton id="dice" alt="W&uuml;rfel mit einer Eins" image="resources/img/wuerfel1.png" action="#{spiel.dice()}" tabindex="4" title="W&uuml;rfel mit einer Eins">
      <f:ajax render="gameinfo" onevent="animate" />                            
  </h:commandButton>

将您的animate功能更改为

function animate(data) {
    if (data.status === 'success') {
        //your original code goes here...
    }
}

另外:阅读BalusC的这个答案:在ajax调用后处理onclick函数

于 2013-05-08T15:06:24.130 回答