2

我有一个需要一些输入的表格,那里的一切都很漂亮。我想从这个表单中获取一个输入值并通过 jquery 将其分配给一个隐藏值。为此,我编写了以下内容:

<script type="text/javascript">
    jQuery(document).ready(function() {
        function preventDefault(e){
            e.preventDefault();
        }

        jQuery('#rsvp-form').bind('submit', preventDefault);
        jQuery('#rsvp-form').submit(function(e) {
            var emailvalue = jQuery('#personemail\\[0\\]').val();
            jQuery('#person_email').val(emailvalue);
            alert(jQuery("#person_email").val());
            jQuery('#rsvp-form').unbind('submit', preventDefault);
            jQuery(this).trigger('submit');
        });
    });
</script>

我将 .preventDefault 绑定到提交就好了,并且没有问题地更改我的值。问题是在更改值后提交表单。无论我尝试过什么,它都会以无限循环结束。如果我删除触发器或 .submit() 或类似的东西,然后将其保留为 unbind,则不会发生任何事情。在这一点上有点难过。

4

2 回答 2

3

你不应该需要这些。如果您想在表单提交之前设置该值,您可以像这样轻松地这样做:

jQuery(function() {
    jQuery('#rsvp-form').submit(function(e) {
        var emailvalue = jQuery('#personemail\\[0\\]').val();
        jQuery('#person_email').val(emailvalue);
    });
});
于 2011-05-09T16:50:17.420 回答
3

您需要调用本机submit方法,而不是触发 jQuery 事件。

jQuery('#rsvp-form').submit(function(e) {
    var emailvalue = jQuery('#personemail\\[0\\]').val();
    jQuery('#person_email').val(emailvalue);
    alert(jQuery("#person_email").val());
    jQuery('#rsvp-form').unbind('submit', preventDefault);
    this.submit(); // <-- this line here
});
于 2011-05-09T16:51:21.727 回答