在提交之前更改输入字段

时间:2009-11-02 11:02:52

标签: jquery

我必须使用重音码为特定注册商编码域名(IDNA)。

我有一个简单的输入字段:

<input type="text" id="idndomain" name="sld[0]" size="40" />

我的jQuery函数

$(document).ready(function() { 
    $('#domainform').submit(function(){
        $.getJSON("includes/idna/idna.php", {
            domain: $("input#idndomain").val()
        }, function(data){
            $("div#result").html($('<b>' + data.encoded + '</b>'));
            $('#idndomain').val(data.encoded);
        });
        return true;
    });
}); 

所以我向idna.php发送一个查询,该查询对域名进行编码并返回一个json数组:

{"encoded":"xn--caf-dma.ch"}

问题是表单是使用'original'值提交的,而不是json查询返回的值。

问题是:如何首先'等待'json结果,用编码的字符串替换输入字段并提交?

1 个答案:

答案 0 :(得分:7)

尝试绑定到提交按钮而不是表单,并在json调用的成功回调中显式调用表单的submit处理程序:

    $(document).ready(function() { 
            $('#submitButton').click(function(){

                    // maybe disable the submit button once clicked?
                    $(this).attr('disabled', true); 
                    $.getJSON("includes/idna/idna.php", {
                            domain: $("input#idndomain").val()
                    }, function(data){
                            $("div#result").html($('<b>' + data.encoded + '</b>'));
                            $('#idndomain').val(data.encoded);
                            // now submit the form
                            $('#domainform').submit();
                    });
                    return false;
            });
    });