3

问题解决了

我已经搜索了几个信息来源来寻找此类问题。但是没有确切的解决方案。问题是我无法使用 ajax 将复选框值传递给 div id。它一直在父窗口中打开。这是我的代码。

Javascript:

<script type="text/javascript">
$(document).ready(function() {  
    $("#villa_submit").click(function() {   
        var action = $("#villa_choose").attr('action');
//var form_data = { 'vid[]' : []};$("input:checked").each(function() {data['vid[]'].push($(this).val());});
var form_data = $('#villa_choose').serialize();  //suggested by Kev Price 
        $.ajax({
            type: "POST",
            url: action,
            data: form_data,
            beforeSend:function(){
                $('#villa_result').html('<center><img src="/images/loading.gif" alt="Loading..." align="absmiddle"/> loading...</center>');
              },
            success: function(data){
                  $('#test_result').html(data);
            }
        });     
        return false;
    }); 
});
</script>

HTML:

<form name="villa_choose" id="villa_choose" method="post" action="">
<input type="checkbox" name="vid[]" id="vid1" value="1" />
<input type="checkbox" name="vid[]" id="vid2" value="2" />
<input type="checkbox" name="vid[]" id="vid3" value="3" />
<input type="checkbox" name="vid[]" id="vid4" value="4" />
<input type="checkbox" name="vid[]" id="vid5" value="5" />
</form>

<div id="test_result"></div>
4

3 回答 3

3

您有多个<input>具有相同id属性的元素。这是不允许的,id在文档中必须是唯一的。修复它,然后重试。

于 2012-11-08T17:16:48.100 回答
3

一旦你解决了 Madbreaks 建议的问题,你可以在你的 jquery 中将复选框值放入这样的数组中

var values = $("input[type='checkbox']:checked").map(function () {
    return this.value;
}).get();

values will be an array that you can pass with ajax like this

var data = 'checkbox="'+values+'"';
$.ajax({
    url: "process.php",
    type: "GET",
    data: data,
    cache: false,
    success: function (html) {
        ... // change html on return
    }
});

希望有帮助

于 2012-11-08T17:23:43.573 回答
0

var data = $("#villa_choose").serializeArray();

$.ajax({

网址:“process.php”,

类型:“获取”,

数据:数据,

缓存:假,

成功:函数(html){

})

});

于 2015-09-04T09:48:14.820 回答