我有一个数据列表,列表中有点击展开效果。由于这个数据列表用到了ajax
加载,就是ajax
加载之后的click
时间不起作用了,希望各位大神帮忙看看。
这是html
中的数据结构和页面布局
<div class="con-list">
<div class="list-data">
<div class="list-data-detail">
<p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场<p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1603">展开</a></p>
</div>
<div class="list-data-detail">
<p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场<p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1621">展开</a></p>
</div>
<div class="list-data-detail">
<p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场<p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1625">展开</a></p>
</div>
<div class="list-data-detail">
<p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场<p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1633">展开</a></p>
</div>
</div>
<div class="list-data html-hide"></div>
</div>
js
中的展开click
事件和ajax
请求如下
<script>
;(function($){
//打开
$('.open-detail').click(function(){
$(this).parent().siblings('p[class="no-open"]').addClass('yes-open');
$(this).text('收起');
$(this).attr('class', 'close-detail');
});
//收起
$('.close-detail').click(function(){
$(this).parent().siblings('p[class="yes-open"]').addClass('no-open');
$(this).text('展开');
$(this).attr('class', 'open-detail');
});
//
});
function getAjaxList(_v, _c, _t){
$.ajax({
url : './ajax.php?op='+_v,
type : 'post',
dataType : 'json',
data : {'category':_c, 'template':_t},
success : function(msg){
if(msg.status == 1){
$('.html-hide').html(msg.html);
$('.html-hide').siblings('div').hide();
$('.html-hide').show();
} else {
$('.list-data').html('此处无您要的信息,到最新动态去看看吧');
}
}
});
}
</script>
php
中的div
设置及数据设置
<?php
...
...
...
foreach ($variable as $key => $value) {
$html .='<div class="list-data-detail">';
$html .='<p class="no-open">'.$value['desc'].'<p>';
$html .='<p><span>时间:'.date('Y-m-d', $value['updateTime']).'</span> | <span>来源:'.$value['author'].'</span> <a href="javascript:(0)" class="open-detail" data-id="'.$value['aid'].'">展开</a></p>';
$html .='</div>';
}
$result['html'] = $html;
exit(json_encode($result));
我在php
中div
中的样式都加了啊!可就是不行。
谢谢邀请。我之前也遇到这种类似的问题,也是
ajax()
加载完的数据导致原来加的效果失效。如下是我的处理方式之后通过网上查询才知道这个
live()
其实和bind()
差不多一样用,都是可以给未来元素绑定对应的触发事件,但是二者还是有区别的。两者你都试试看,希望对你有帮助