每次表单输入字段更改时发送ajax请求

时间:2013-12-07 14:24:49

标签: javascript jquery ajax forms

每次使用jQuery更改事件更改表单元素时,我都需要创建一个发送ajax请求的表单。通过这样做,我能够获得表单输入值以显示在跨度中:

<form id="TestForm" class="form-horizontal">
    <div class="form-group">
        <label for="namefirst" class="col-sm-2 control-label">First Name</label>
        <div class="col-sm-6">
            <input id="firstname" type="text" name="firstname" class="form-control" placeholder="Enter your first name" /><span id="spanfirstname"></span>
        </div>
    </div>
    <div class="form-group">
        <label for="namelast" class="col-sm-2 control-label">Last Name</label>
        <div class="col-sm-6">
            <input id="lastname" type="text" name="lastname" class="form-control" placeholder="Enter your last name" /><span id="spanlastname"></span>
        </div>
    </div>
    <div class="form-group">
        <label for="email" class="col-sm-2 control-label">Email</label>
        <div class="col-sm-6">
            <div class="left-inner-addon"> <i class="glyphicon glyphicon-envelope"></i>
                <input id="email" type="text" name="email" class="form-control" placeholder="Enter your email" /><span id="spanemail"></span>
            </div>
        </div>
    </div>
    <div class="form-group">
        <label for="phone" class="col-sm-2 control-label">Phone</label>
        <div class="col-sm-6">
            <div class="left-inner-addon"> <i class="glyphicon glyphicon-phone-alt"></i>
                <input id="phone" type="text" name="phone" class="form-control" placeholder="Enter your phone number" /><span id="spanphone"></span>
            </div>
        </div>
    </div>
    <div class="form-group">
        <label for="password" class="col-sm-2 control-label">Password</label>
        <div class="col-sm-6">
            <input id="password" type="password" name="password" class="form-control" placeholder="Enter a password" /><span id="spanphone"></span>
        </div>
    </div>
    <div class="form-group">
        <label for="password" class="col-sm-2 control-label"></label>
        <div class="col-sm-6">
            <button class="button green major beeboop" name="button" type="submit">This is a test</button>
        </div>
    </div>
</form>
<div id="result"></div>
<div class="row spacer"></div>
</div>
<!-- /container -->
<script src="//code.jquery.com/jquery.js"></script>
<script type="text/javascript">
    $(document).ready(function() {
        $('#firstname').change(function() {
            $('#output_firstname').val($(this).val());
            $('#spanfirstname').html('<b> TestForm: firstname:' + $(this).val() + '</b>');
        });
        $('#lastname').change(function() {
            $('#output_lastname').val($(this).val());
            $('#spanlastname').html('<b>' + $(this).val() + '</b>');
        });
        $('#email').change(function() {
            $('#output_email').val($(this).val());
            $('#spanemail').html('<b>' + $(this).val() + '</b>');
        });
        $('#phone').change(function() {
            $('#output_phone').val($(this).val());
            $('#spanphone').html('<b>' + $(this).val() + '</b>');
        });
        $('#password').change(function() {
            $('#output_password').val($(this).val());
            $('#spanpassword').html('<b>' + $(this).val() + '</b>');
        });
    });
</script>

我尝试在更改事件函数中包装ajax请求但没有成功:

<script>
    $(document).ready(function() {
        $('#firstname').change(function() {
            jQuery.post("ajax-process.cfm", {
                firstname: jQuery('#firstname').val()
            }, function(data) {

            });
            return false;
        });
    });
</script>

@ omar-ali @Anil Namde更新了代码。但现在我只能在控制台中获得第一个值:

$("input[type='text']").change(function() {
var firstname = $("#firstname").val();
var lastname = $("#lastname").val();
var email = $("#email").val();
$.ajax({
url : "ajax-process.cfm",
type: "POST",
data: {
    firstname: firstname,
    lastname: lastname,
    email: email
},
success: function(data) {
$("#simple-msg").html('<pre><code>' + data +  '</code></pre>');
}
});
});

1 个答案:

答案 0 :(得分:1)

我尝试了你的代码,但我没有调用任何ajax请求,只是放了一个console.log('testing');

有效。

我猜你没有意识到(我的感觉)是......当你输入文本框中的焦点时,更改被称为不是你输入的。

此外,最好使用

var getallyourvalshere = $('#firstname').val();

$.post('linktoyourscript.php',{ firstname: getallyourvalshere }, function(data) {
    //do stuff, console.log(data); 
});

为什么使用return false;