排序功能
原创
©著作权归作者所有:来自51CTO博客作者TBHacker的原创作品,请联系作者获取转载授权,否则将追究法律责任
布局
<thead>
<tr>
<th>ID</th>
<th>标题</th>
<th>浏览人次 <i data-type="user_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>浏览数 <i data-type="browse_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>真实点赞 <i data-type="zan_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>虚假点赞 <i data-type="fake_zan_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>前端点赞数 <i data-type="show_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>三分之一离开 <i data-type="1_3_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>三分之二离开 <i data-type="2_3_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>阅读完离开 <i data-type="3_3_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>转发次数 <i data-type="transpond_num" class="fa fa-sort sort" style="cursor: pointer;"></i></th>
<th>标签</th>
</tr>
</thead>
埋藏变量
<input type="hidden" name="sort_name" id="sort_name" value="{$sort_name}" />
<input type="hidden" name="sort_type" id="sort_type" value="{$sort_type}" />
触发
function get_search(){
var type = $("#type").val();
var title = $("#title").val();
var search_str = '';
if(type) search_str +='&type=' + type;
if(title) search_str +='&title=' + title;
return search_str;
}
$("#search").on('click',function () {
var search_str = get_search();
window.location.href = '__URL__/news?page=' + 1 + search_str;
});
$(".sort").on('click',function() {
let search_str = get_search();
let type_name = $(this).data('type');
let sort_name = $('#sort_name').val();
let sort_type = $('#sort_type').val();
if (type_name == sort_name) {
if (!sort_type || sort_type == 'asc') {
sort_type = 'desc';
} else {
sort_type = 'asc';
}
} else {
sort_type = 'desc';
}
search_str +='&sort_name=' + type_name + '&sort_type=' + sort_type;
window.location.href = '__URL__/news?page=' + 1 + search_str;
});
数据处理
if (!empty($_GET['sort_name']) && !empty($_GET['sort_type'])) {
$sort_name = trim($_GET['sort_name']);
$sort_type = trim($_GET['sort_type']);
$this->assign('sort_name', $sort_name);
$this->assign('sort_type', $sort_type);
$order = $sort_name.' '.$sort_type;
}
$result_list = $newsModel->where($where)->limit($start . ',' . $step)->field('*,zan_num+fake_zan_num show_num')->order($order)->select();