Process onclick function after ajax call

后端 未结 1 567
时光取名叫无心
时光取名叫无心 2020-11-28 10:05

I\'m trying to select and focus to choosed component ID after submit a form (ajax call).



        
相关标签:
1条回答
  • 2020-11-28 10:45

    The onevent handler will actually be invoked three times and it should point to a function name, not the function itself. One time before the ajax request is been sent, one time after the ajax response is been arrived and one time when the HTML DOM is successfully updated. You should be checking the status property of the given data argument for that.

    function listener(data) {
        var status = data.status; // Can be "begin", "complete" or "success".
    
        switch (status) {
            case "begin": // Before the ajax request is sent.
                // ...
                break;
    
            case "complete": // After the ajax response is arrived.
                // ...
                break;
    
            case "success": // After update of HTML DOM based on ajax response..
                // ...
                break;
        }
    }
    

    In your particular case, you thus just need to add a check if the status is success.

    function myFunc(data) {
        if (data.status == "success") {
            var element = document.getElementById('form:#{bean.componentId}');
            element.focus();
            element.select();
        }
    }
    

    And you need to reference the function by its name:

    <f:ajax ... onevent="myFunc" />
    
    0 讨论(0)
提交回复
热议问题