drxpt06820 2015-10-08 02:09
浏览 40
已采纳

单击复选框时停止触发功能

I am using jquery to print the following table. Table has two columns. one for the values and other for the check boxes. Problem I am facing is when I click a checkbox, it is triggering the function which is supposed to be triggered only when the value clicked.

Can somebody tell me how to stop triggering the function when a check box is clicked?

PHP code that prints the table

<table border='1' cellspacing='12' cellpadding='4' style='border-collapse: collapse' width='700' id=topictable >

<?php while ($row = mysql_fetch_assoc($results)) {
    $topic = $row['topic']; 
?>
<tr bgcolor='white'>
<td class='value'><a href='#'><?php $topic ?></a></td>
<td bgcolor='white'width='5%'><input type=checkbox name=chekboxTopic[] value= <?php $topic ?> </td>
</tr>
<?php
}
?>
</table>

Java script

$(document).on("click","#topictable td", function() {
    // to set the session variable`enter code here`
    var strSelectedTopic = ($( this ).text());
    alert(strSelectedTopic);
    var switchval = "setsessiontopic";
     var param = "switchval=" + switchval + "&topic=" + strSelectedTopic;
     ajaxSend(param);
    var form = document.getElementById("abcd");
    form.action = "design.php"
    form.target = "_blank";
    form.submit();
    return false;

});
  • 写回答

1条回答 默认 最新

  • dreamwind1985 2015-10-08 04:21
    关注

    Couple things.

    1. Close off your inputs
    2. Change what is supposed to be clicked; make it more specific

    Demo: http://jsfiddle.net/dL3s3acn/

    <table border='1' cellspacing='12' cellpadding='4' style='border-collapse: collapse' width='700' id=topictable >
    <?php
        while ($row = mysql_fetch_assoc($results)) {
            $topic = $row['topic'];
    ?>
        <tr bgcolor='white'>
            <td class="value"><a href="#"><?php $topic ?></a></td>
            <td bgcolor="white" width="5%"><input type="checkbox" name="chekboxTopic[]" value="<?php $topic ?>" /></td>
        </tr>
    <?php
        }
    ?>
    </table>
    <script>
    // Click on the class ".value" not "td", that is too broad
    $(document).on("click","#topictable .value", function() {
        // to set the session variable`enter code here`
        var strSelectedTopic = ($(this).text());
        alert(strSelectedTopic);
        var switchval   =   "setsessiontopic";
        var param       =   "switchval="+switchval+"&topic="+strSelectedTopic;
        ajaxSend(param);
        var form        =   document.getElementById("abcd");
        form.action     =   "design.php"
        form.target     =   "_blank";
        form.submit();
        return false;
    });
    </script>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。