1. wordpress文章排序如何按ID来排序
你可以向posts_orderby这个hooks添加内容。位于wp-includes/query.php
中 3206行。
如:
add_filter( 'posts_orderby', 'wpdit_custom_orderby' );
function wpdit_custom_orderby( $orderby ) {
$orderby = "ID ASC";
return $orderby;
}上面的代码是改变了全局的排序方式。
如果仅想在需要的地方设定不同的排序,就只要改你的代码:
$args = array(
'cat' => get_option('cx_cat_s'),
'post__not_in' => $sticky,
'paged' => $paged,
'orderby' => 'ID', //这样插入就可以了
'order' => 'ASC'
);
2. wordpress某一个分类的文章按照发布顺序来排序
嗯,这个你可以参阅网页链接 这个wordpress教程的一些方法。如果只想让A分类的文章列表按 最先发布的文章排在最前面——'order'=>'ASC';
需要加一个判断分类判断:
if(is_category('A分类的ID号'){
$args = array(
'showposts' => 10, //显示数量
'cat' =>1 //这个数值是你分类的ID
'orderby' => 'date' //按照日期排序
'order'=>'ASC'
);
}else{
这里是其它分类
}
希望帮到你了。
3. wordpress3.8发布文章id不连续怎么解决
如果你不是特别在意,连不连续也是无关紧要的,本文对你来说也没多大意义了。
一、禁用文章修订版 所谓的文章修订版就是你每次修改一次文章,它都会自动帮你保存修改之前的文章版本,专业术语叫做版本控制,这样保证了在误修改的情况下可以还原之前的内容,这个在维基文档的维护方面是有很大帮助的,但是作为我们的小博客,似乎没多大用处,而且这个修订版在数据库中是占据一个ID的,这也是导致文章ID不连续的问题之一。要想禁用文章修订版,可以在 wp-config.php文件中添加:1define('WP_POST_REVISIONS', false);二、删除文章修订版 禁用了文章修订版之后,数据库中还是保存着之前已经创建的文章修订版,这些其实已经没多大用处,而且占着ID,我们可以将它删除。
至于怎么删除,可以在 phpmyadmin 中执行以下SQL语句(做好备份):12345DELETE a,b,cFROM wp_posts aLEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)WHERE a.post_type = 'revision';三、删除不必要的附件 相信很多博友在发布文章都会同时上传/插入一些附件,如图像、视频、音乐等,这些附件可以在WordPress管理后台 – 媒体库中看到,不同媒体对应了不同的文章。可是你要注意的是这些媒体也是占据着文章ID的,它们与文章都保存在同一个数据库表wp_posts中。
如果你特别追求文章的ID一定要完美无缺地连续,请不要在发布文章的时候上传/插入这些媒体,并请在WordPress管理后台 – 媒体库中,删除之前上传的媒体(注意这个操作不只是删除记录,而且会删除你上传的文件),需要的话请用FTP重新上传这些文件。四、禁用自动保存 自动保存的好处是你在编辑文章的时候,每隔一小段时间系统会自动帮你保存编辑的文章,防止网页突然关闭,导致之前写的几千字哗啦一下全没了。
缺点是每篇都文章都会有一个自动保存的记录,同样占据一个文章ID,也是文章ID不连续的原因之一,如果你不需要这个功能,请在以下两个文件中:12wp-admin/post-new.phpwp-admin/post.php注释掉这行:1//wp_enqueue_script('autosave');五、重新排列不连续的文章ID 以下方法已不支持最新版WordPress。完成以上四步,基本上可以保证以后发布的文章ID都会是连续的了,但是之前已经发布的文章ID还是一片混乱,得把他们重新排列,以保证是ID是连续的。
我写了一个PHP脚本,你可以通过以下网址下载,下载后用文本编辑器打开,根据开头的说明修改数据库信息,然后将该PHP文件上传至你的博客空间,运行一下看到OK就可以了,你可以到phpmyadmin中查看wp_posts表中的id是不是连续的了。还是那句话,开始之前请先备份你的数据库。
(如果你使用了post id作为固定链接,那么将可能改变所有文章的网址,会影响搜索引擎收录;如果你用的插件建立了新的数据库表,如投票插件等,也将会出现问题;如果你的博客中创建了父子关系的页面,运行了以下脚本将会失去此关系。请慎用!)。
4. 请问wordpress中如何给每篇文章按顺序加上排名
很简单啊。
首先你得知道你这个按照浏览量排序显示文章的函数位于哪个页面哪个位置,肯定是位于主循环中的,一般应该在index.php中,然后在要显示的位置添加一个层(也可以根据需要不添加层,这样就只要第二行): <?php echo ++$listnumber ?> 然后再在CSS中控制listnumber的样式即可。 这个代码不严谨,不过可以实现你所要的功能。
本地localhost通过,我这个没有按热度排序,只是默认的时间顺序排序,不过原理是一样的。 。
5. WordPress如何让当前分类的文章列表按阅读量排列和热评数量排列
按阅读量排列,可安装插件 wp-postviews ,该插件提供了热门阅读文章列表调用代码: <?php if="" (function_exists('get_most_viewed')):="">?php> <?php get_most_viewed(); ?> <?php endif; ?> 或者 <?php if(function_exists('the_views'))="" {="" the_views();="" }="" ?=""> 或者 //显示最热门文章<?php get_most_viewed($mode='' ,="" $limit="10," $chars="0," $display="true)" ?="">//显示某个或某些目录下最冷门文<?php get_least_viewed_category($category_id="0," $mode='' ,="" $limit="10," $chars="0," $display="true)" ?="">//显示某个或某些目录下最热门文章<?php get_most_viewed_category($category_id="0," $mode='' ,="" $limit="10," $chars="0," $display="true)" ?="">//显示指定标签下的最热门文章<?php get_most_viewed_tag($tag_id="0," $mode='' ,="" $limit="10," $chars="0," $display="true)" ?="">//显示指定标签下的最冷门文章<?php get_least_viewed_tag($tag_id="0," $mode='' ,="" $limit="10," $chars="0," $display="true)" ?="">//显示全站文章总共被浏览过多少次<?php get_totalviews();="" ?=""> 特定时间内阅读量: ### Function: Get TimeSpan Most Viewedfunction get_timespan_most_viewed($mode = '', $limit = 20, $days = 30, $display = true) {global $wpdb, $post;$limit_date = current_time('timestamp') - ($days*86400);$limit_date = date("Y-m-d H:i:s",$limit_date);$where = '';$temp = '';if(!empty($mode) && $mode != 'both') {$where = "post_type = '$mode'";} else {$where = '1=1';}$most_viewed = $wpdb->get_results("SELECT DISTINCT $wpdb->posts.*, (meta_value+0) AS views FROM $wpdb->posts LEFT JOIN $wpdb->postmeta ON $wpdb->postmeta.post_id = $wpdb->posts.ID WHERE post_date < '".current_time('mysql')."'="" and="" post_date=""> '".$limit_date."' AND $where AND post_status = 'publish' AND meta_key = 'views' AND post_password = '' ORDER BY views DESC LIMIT $limit");if($most_viewed) {foreach ($most_viewed as $post) {$post_title = get_the_title();$post_views = intval($post->views);$post_views = number_format($post_views);$temp .= "$post_title - $post_views ".__('views', 'wp-postviews')."";}} else {$temp = ''.__('N/A', 'wp-postviews').''."\n";}if($display) {echo $temp;} else {return $temp;}} $days这个参数是多长时间内发表的文章,设置为30,就是1个月的热门文章。
转载请注明出处51数据库 » 让wordpress文章id重新排列
?php>?php>?php>?php>?php>?php>?php>