weixin_33720078 2011-04-24 14:28 采纳率: 0%
浏览 32

使用$ .ajax发送数据时出现问题

I made a form using radio button (for poll).
And I use $.ajax to submit the form.
but when I use $("#polling").serialize() for the data, there is nothing sent/requested...


Are there any problem with the radio button?
$(function(){ $("input[name=vote]").click(function(){
  var id_polling = $("input[name=id_polling]");
  $("div[class=poll-content]").text("Loading");
  $.ajax({
    type: "POST",
    url: BASE_URL + "/processes/polling.php",
    data: $("#polling").serialize(),
    success: function(msg){
      document.getElementById("poll-content").innerHTML = msg;
    }
  });
});

and this is the HTML code :

<div class="poll-content" id="poll-content">
    <form action="#" id="polling">
    <?php
    $poll = Polling::_find_by_id($id);
    $view = "<h4 class=\"polling\">" . $poll->nama . "</h4>";
    $options = explode(",", $poll->opsi);
    foreach ($options as $i => $option) {
        $view .= "<input type=\"radio\" class=\"option\" name=\"option\" value=\"" . $option . "\" />";
        $view .= $option;
        $view .= "<br />";
    }
    $view .= "<input type=\"hidden\" name=\"id_polling\" value=\"" . $poll->id_polling . "\">";
    echo $view;
    ?>
    <input type="button" name="vote" value="Vote" />
    </form>
</div>
  • 写回答

1条回答 默认 最新

  • weixin_33744141 2011-04-24 14:52
    关注

    At first look it appears you are missing a closing });

    $(function() {
        $("input[name=vote]").click(function() {
            var id_polling = $("input[name=id_polling]");
            $("div[class=poll-content]").text("Loading");
            $.ajax({
                type: "POST",
                url: "/echo/html/",
                data: $("#polling").serialize(),
                success: function(msg) {
                    document.getElementById("poll-content").innerHTML = msg;
                }
            });
        });
    }); //<-Missing this to close out dom ready
    

    Edit, after looking at your markup, doing $("div[class=poll-content]").text("Loading"); will destroy the form so your call to $("#polling").serialize() will fail.

    Try to capture the form before you call .text()

    $(function() {
        $("input[name=vote]").click(function() {
            var id_polling = $("input[name=id_polling]");
            var formData = $("#polling").serialize();
            $("div[class=poll-content]").text("Loading");
            $.ajax({
                type: "POST",
                url: "/echo/html/",
                data: formData,
                success: function(msg) {
                    document.getElementById("poll-content").innerHTML = msg;
                }
            });
        });
    });
    

    Example on jsfiddle

    Side note, you can use the class selector instead of the attribute selector $("div.poll-content").text("Loading");

    评论

报告相同问题?

悬赏问题

  • ¥15 求帮我调试一下freefem代码
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图