表格 行的单击事件为何不生效?
<style>
.tr-click{
background-color: #EFA2A9 ;
}
table tr:hover{
background-color: #EFA2A9 ;
}
</style>

<table class="table">
<tr>
<td>123</td>
<td>123</td>
<td>123</td>
</tr>
<tr>
<td>123</td>
<td>123</td>
<td>123</td>
</tr>
</table>

<button id="btn">改变表格</button>

<script type="text/javascript" src="jquery/jquery.min.js" ></script>

<script type="application/javascript">

$(function(){
$("tr").click(function(){
alert('123');
$("tr").removeClass("tr-click");
$(this).addClass("tr-click");
})

$("#btn").click(function(){
var html="<tr><td>000</td><td>000</td></tr><tr><td>000</td><td>000</td></tr>";
$(".table").replaceWith("<table>"+html+"</table>");
})
})

</script>

如代码建一个表格,为表格的行设置单击事件,更换背景色,此时单击事件正常。
同时设置一个按钮,通过按钮单击事件使用replaceWith方法替换表格内容,这个时候表格行的单击事件不生效了。
百思不得其解,在浏览器查看了源代码,发现多了<tbody></tbody>标签,但是我设置的单击事件选择器是 tr ,就算多了tbody标签也不应该不生效吧,大佬们帮忙看看是怎么回事,万分感谢。

2个回答

替换表格内容后要重新注册事件,你注册的这个点击事件是被替换掉的dom,新增的dom没有注册事件,所以点击无效
js部分写成这样应该就可以了。
至于多了个tbody,是由于你没有按照规范写,浏览器自动加上tbody了,表格格式:

<script type="application/javascript">

$(function(){
    $("tr").click(function(){
        alert('123');
        $("tr").removeClass("tr-click");
        $(this).addClass("tr-click");
    })

    $("#btn").click(function(){
        var html="<tr><td>000</td><td>000</td></tr><tr><td>000</td><td>000</td></tr>";
        $(".table").replaceWith("<table>"+html+"</table>");

        $("tr").click(function(){
            alert('123');
            $("tr").removeClass("tr-click");
            $(this).addClass("tr-click");
        })
    })
})

</script>
qq_39105418
Java首席劝退师 谢谢大佬解惑
12 个月之前 回复
qq_37147630
Print_v 表格格式那部分可以忽略。。。。。没写上去
12 个月之前 回复

你用replaceWith()等于是重新创建一个表格来替换原来的表格。
你的单击事件是设置在原来的表格上的,新创建的表格没有设置事件。

解决方法是replaceWith()替换表格之后重新对新创建的表格设置事件。
或者用委托事件的绑定方法,把单击事件委托给表格的父元素,如:

$(".table").parent().on("click", "tr",function(){
alert('123');
$("tr").removeClass("tr-click");
$(this).addClass("tr-click");
})
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐