datatables在服务器端构建数据结构的getData.php核心代码
$columns = array(
array( 'db' => 'ID', 'dt' => 0 ),
array( 'db' => '标题', 'dt' => 1, 'formatter' => function( $d, $row ) {
return $d . ' 'ID'] . '">';
} ),
array( 'db' => '浏览数', 'dt' => 2 )
);
ajax代码
$(document).on("click", ".fa-heart-o, .fa-heart", function() {
var id = $(this).data('id');
$.ajax({
url: 'update_favorites.php',
type: 'post',
data: { id: id },
beforeSend: function (xhr) {
},
success: function(res) {
if (res.is_favorited) {
$(".fa-heart-o[data-id='" + id + "']").removeClass("fa-heart-o").addClass("fa-heart");
} else {
$(".fa-heart[data-id='" + id + "']").removeClass("fa-heart").addClass("fa-heart-o");
}
},
});
});
php代码略了吧~核心就这几句
$is_favorited = $row['is_favorited'];
if ($is_favorited == 1) {
$sql = "UPDATE data_content SET is_favorited=0 WHERE id=$id";
} else {
$sql = "UPDATE data_content SET is_favorited=1 WHERE id=$id";
}
这样在php端构建了表格,前端接收就可以看到数据了,标题后面是数据构建是增加的.fa-heart-o按钮,通过ajax实现了点击该按钮就可以对该标题进行关注的开关(点一下是关注,再点一下是取关),但由于这个.fa-heart-o按钮是动态添加进表格里面的,点击之后再想找到它并给他修改class为.fa-heart就异常艰难。唉,最近被这个动态添加的事情搞得头大死了。
所以就想能不能在构建表格的时候就给他加上一个什么标志,但是怎么加都是动态数据,还是很难找到。
所以:我明明已经查到数据库这个标题已经被收藏了,就是不能实时刷新class为.fa-heart,这个问题咋办呢?
注:
.fa-heart-o是空心按钮
.fa-heart是实心按钮