php之微型博客的创建,WordPress增加文章排序方式
分类:多线程

露兜博客首页的访客可自行选择文章排序方式的效果是怎么做的,今天就来给大家分享这个文章排序效果的实现过程。
图片 1
其实实现过程也比较简单,一个是构造链接,另外一个是使用query_posts来改变一下主循环就可以了。
构造链接
链接主要用于传递GET参数,让PHP程序知道你到底想怎么排序。在主题的index.php中你需要的位置插入以下代码,用于输出排序按钮的HTML,这个排序按钮的样式,你再自己写写css咯。需要注意的是以下代码会自动获取当前用户已选择的排序方式,并给这个排序按钮的 li 添加了class="current"

一,微型博客的开发思路

 图片 2

我们常见的WordPress站点文章排序,通常情况下是按发布时间的升序或降序方式排列,这种排序方式几乎可以满足大多数站点的需求了,但是有些另类的站点可能会有一些另类的需求:我想手动修改文章的排列方式,可以随意更改文章的排列位置。其实WordPress的query_posts就可以轻松解决这个问题,不过你得自己动手改一些代码。

复制代码代码如下:

微型博客的创建,确定无疑我们会用到PHP和mysql之间的增添删改查,首先来看一下思维导图:图片 3

分页代码

修改方法
1、打开WordPress当前主题目录,打开index.php,搜索代码:

文章排序

  • href="/?order=rand" rel="nofollow">随机阅读
  • href="/?order=commented" rel="nofollow">评论最多
  • href="/?order=alpha" rel="nofollow">标题排序

改变主循环
首先你得先在主题的index.php中找到以下语句:

复制代码代码如下:
if (have_posts())

然后在这句之前添加以下代码:

复制代码代码如下:
if ( isset($_GET['order']) )
{
switch ($_GET['order'])
{
case 'rand' : $orderby = 'rand'; break;
case 'commented' : $orderby = 'comment_count'; break;
case 'alpha' : $orderby = 'title'; break;
default : $orderby = 'title';
}

global $wp_query;
$args= array('orderby' => $orderby, 'order' => 'DESC');

$arms = array_merge($args, $wp_query->query);
query_posts($arms);
}

if (have_posts())

好了,就这么简单,复制粘贴,轻轻松松实现排序效果

搭建好计算机里的apache php 和mysql的联动功能,打开phpmyadmin,创建一个数据库,在这个数据库里创建一个数据表。

 代码如下

复制代码代码如下:
while (have_posts())

二,开发所需的各个项目

<?php
  //page当前页,num每页的页数
  $page=isset($_GET['page'])?intval($_GET['page']):1;
  $num=5;
  $conn = mysql_connect('127.0.0.1','root','');
  if (!$conn) {
   die('Could not connect:'.mysql_error());
  }
  mysql_select_db('shop');
  //获取记录总数
  $total=mysql_num_rows(mysql_query("select * from user"));
  //计算页数
  $pagenum=ceil($total/$num);
  //限制页数不能超出范围
  If($page>$pagenum || $page == 0){
    Echo 'Error : Can Not Found The page.';
    Exit;
  }
  //语句“Select * from table limit 0,10”从table表提取十条信息,0为起点,10为提取的数目
  //$offset为起点值,如当前页为第一页,每页5条,起点即为0,同理当前为第二页,起点将为5
  $offset=($page-1)*$num;
  $result=mysql_query("select * from user limit $offset,$num");
  while($it=mysql_fetch_array($result)){
    echo 'id:'.$it['id'].' name:'.$it['name'].'<br />';
  }
  //显示链接页面切换链接,当前页无链接
  for($i=1;$i<=$pagenum;$i++){
    $show=($i!=$page)?"<a href='index.php?page=".$i."'>$i</a>":"<b>$i</b>";
    echo $show." ";
  }
  echo $total.'条记录,每页5条,共'.$pagenum.'页';
   mysql_free_result($result);
  mysql_close($conn);
?>

将其替换成:

1,公共模板(conn.php)

实例2

复制代码代码如下:
/**
* 名称:WordPress手动修改文章排列顺序
* 最后修改:2010年11月14日
*/
$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
$args=array(
'meta_key' => 'sort',
'orderby' => 'meta_value_num', // 须 WordPress 2.8 及以上版本
'paged' => $paged,
'order' => DESC
);
query_posts($args);
while (have_posts())

<?php

 代码如下

接着搜索:

  @mysql_connect("localhost","root","")or die("mysql连接失败");

<?

复制代码代码如下:
endwhile;

  @mysql_select_db("phplearn")or die;

//function.php  这里是主函数
function php_page($page_dbname,$page_size,$page)
{
if ($page=="")
 {$page=1;};
if ($ljjl=="")
 {$ljjl=0;};
if($page)
  {
    //$page_dbname="tb_insert";
 //$page_size=4;          //每页显示4条记录
    $query="select count(*) as total from ".$page_dbname;  //从数据库中读取数据
 $result=mysql_query($query);
    $message_count=mysql_result($result,0,"total");  //获取总的记录数
    $page_count=ceil($message_count/$page_size);  //获取总的页数
    $offset=($page-1)*$page_size;  
    $query="select * from ".$page_dbname." order by id desc limit $offset, $page_size";  
 $result=mysql_query($query);
//内容显示 这里只是简单的作个示范,可以按你的要求随便改动。
 while ($myrow=@mysql_fetch_array($result))
 {
  echo $myrow[name]." | ".$myrow[number]." | ".$myrow[tel]." | ".$myrow[address]."<br><br>";
  }
 
}
 echo "页次:".$page."/";
 echo $page_count."页 记录:";
 echo $message_count."条"."<br>";

将其改成:

  //@mysql_set_charset;

  if($page!=1)
   {
    echo  "<a href=index.php?page=1>首页</a> ";
       echo "<a href=index.php?page=".($page-1).">上一页</a> ";
    }
  else
   {
    echo  "首页 ";
       echo "上一页 ";  
   }
 
  for($i=1; $i<=$page_count; $i++)
  {
   if ($page==$i)
    {echo  $i." ";}
    else
       {echo  "<a href=index.php?page=$i>$i</a> ";}
   }
 
  if($page<$page_count)
   {
    echo "<a href=index.php?page=".($page+1).">下一页</a> ";
    echo  "<a href=index.php?page=".$page_count.">尾页</a>";
   }
  else
   {
    echo "下一页 ";
    echo  "尾页";
   }
}
?>

复制代码代码如下:
endwhile;wp_reset_query();

  mysql_query("set names 'gbk'");

//conn.php   连接数据库

2、给之前发表的所有文章添加自定义字段(或者称作自定义栏目,在文章编辑页底部可以看到),名称为 sort ,值填数字。这样在首页,文章的排列顺序就按照sort字段的值,从大到小排列了。通过修改sort字段的值,可以达到自定义文章排列顺序的目的。
3、需要注意的是,通过以上修改后,你必须给所有文章添加自定义字段sort,否则没有添加sort字段的文章将无法在首页显示。这也许就是手动排序需要付出的代价吧,要不然何谓手动?
4、如果你同时想手动修改标签页、分类页等存档页面的文章排列顺序,同样可以按照第一步介绍的方法来操作,修改主题目录下的archive.php等。

?>

 代码如下

上边用到了mysql及具体数据库的连接,分别用到了mysql_connect和mysql_select_db这两个函数,分别用来连接mysql和数据库phplearn。

<?php

mysql_set_charset用于指定数据库编码,mysql_query是数据库sql语句执行函数,可直接在括号内写sql语句。

$id=mysql_connect("localhost","root","root")or dir('连接失败:' . mysql_error());
//mysql_connect("IP","用户名","密码")

值得注意的是“@”符号,它用于屏蔽mysql报错时的提示,避免用户体验不友好及安全性方面的考虑。

if(mysql_select_db("db_database06",$id))
echo "";
else
echo ('连接失败:' . mysql_error());
mysql_query("set names gb2312");
?>

die(),该函数用于数据库连接失败时给与错误提示。

//主程序,将上面俩个文件包含进来,再调用一个php_page()就可完成分页。:)

2, 添加博文页add.php

 代码如下

<?php

 <?php

include;

require_once("conn.php");
require_once("function.php");
php_page("tb_insert",3,$_GET[page]); // "tb_insert"是表名,3是在每页要显示的记录数,$_GET[page]是page的id,直接用就可以了。
?> 

 if(!empty($_POST['sub'])){

上在的一种是文字分页,比如说上一页,下一页之类的,还有一种数字分页,像1,2,3...之类的,这个比较简单,前者稍微复杂些.最后一种是他们2者结合

  $title=$_POST[‘title’];

 代码如下

  $con=$_POST[‘con’];

--> 1 //获取当前页数
         if(isset($_GET['page'])){
             $page = intval($_GET['page']);
         }
         else {
             $page=1;
         }
         $PageSize = 1; //每页的记录数量
         // 获取总数量
         $sql = "select count(*) from blog";
         $result = mysql_query($sql);
         $row = mysql_fetch_row($result);
         $amount = $row[0];
         /*计算总页数
         if($amount){
             if($amount<$PageSize) { //如果总数量小于每页的记录数量$PageSize,那么只有一页.
                 $PageCount = 1;
             }
             if($amount%$PageSize) { //总数量除以每页的记录数量取于
                 $PageCount =& amp;nbsp;(int)($amount/$PageSize)+1;//如果有于,则页数等于总数量除每页的记录数加1
             }
             else{
                 $PageCount =& amp;nbsp;$amount/$PageSize;//没有,则结果是页数
             }
         }
         else{
             $PageCount = 0;
         }*/
         $PageCount = ceil($amount/$PageSize);//总页数=总数量除以每页数量  如果有小树,则进位< span style="color: #008000;">
         if($Page>$PageCount|$page==0){// 如果当前页数大于总页数
             echo "不能发现此页!";
             exit();
         }
      
         //翻页链接
         $PageOut = '';
         if($page==1){//如果页数只有一页
             $PageOut .= '第一页|上一页';
         }
         else{
             $PageOut .= '<a href="index.php?page=1">第一页& lt;/a>|<a href="index.php?page='.($page-1).'">上一页</a>|';
         }
         if($page==$PageCount||$PageCount==0){//如果当前页等于总也数
             $PageOut .= '下一页|尾页';
         }
         else{
             $PageOut .=  '<a href="index.php?page='.($page+1).'">下一页</a>|<a href="index.php?page='.$PageCount.'">尾页</a>';
         }
         //获取数据
         if($amount){
         $sql="select * from blog limit ".($page-1)*($PageSize).",$PageSize";
         $result=mysql_query($sql);
         while($row=mysql_fetch_array($result)){//此段代码只是示例
             $blogs[] = array('bid'=>$row['bid'],'title'=>$row['title']);
             foreach ($blogs as $blog){
             $title=$blog['title'];
             }
             $output = "<a href=index.php?action=blog_del&bid=$blog[bid]>删除</a>".
             "<a href=index.php?action=blog_edit&bid=$blog[bid]>编辑</a>".
             "<a href=index.php?action=blog_view&bid=$blog[bid]>查看</a>";
             include("template/default/blog.tpl.php");
             echo $PageOut;
         }
         for($i=1;$i<=$PageCount;$i++){//数字分页
            $Pageshow = ($i!=$page)?"<a href='index.php?page=".$i."'>$i</a>":"<b>$i</b>";
            echo $PageShow;
          }
          echo $amount.'条记录,每页'.$PageSize.'条,共'.$PageCount.'页';
         }

  $sql="insert into 'news' ('id','title','dates','contents') values (null,'$title',now;

  mysql_query;

  echo "<script>alert;location.href='index.php';</script>"

  }

?>

<div >

<form action="add.php" method="post">

标题<input type"text" name="title"><br/>

内容<textarea rows='5' cols='50' name='con'></textarea><br/>

<input type=‘submit’ name='sub' value='发表'>

</form>

</div>

include调用指定文件;

empty()判断值是否为空;

$_post获取表单post提交方式的值;

insert into‘表名’ (‘字段1’,‘字段2’,‘字段3’,‘字段4’.。。。)values(‘值1’,‘值2’,‘值3’,‘值4’.。。。),

sql插入语句;

location.href="",js页面跳转。

3,首页index.php

<div >

<button><a href="add.php">发博文</a></button>

<from action="" method="get">

<input type="text" name="keys" />

<input type="submit" name="subs" value="搜索" />

</form>

</div>

<?php

include("conn.php");

if (!empty($_GET[keys])){

  $w= 'title' like '%"._GET[keys]."%'";

} else[$w=1;}

$sql="select * from 'news' where $w order by id desc limit 10";

$query=mysql_query;

while(mysql_fetch_array{

?>

<div >

<h1>

<a href="view.php?id= <?php $rs['id'] ?>"><?php echo $rs['title'] ?></a>

</h1>

<p><?php echo $rs['contents'] ?></p>

<span><?php echo $rs['dates'] ?></span>

<p >

<a href="edit.php?id= <?php $rs['id']?>">编辑</a>

<a href="del.php?id= <?php $rs['id'] ?>">删除</a>

</p>

</div>

<?php

}

?>

select * from '表名' [where] [order] [limit], sql 查询语句。

$_GET表单get提交方式,不同于post,是用于查询,运行效率高,但安全性较差。

mysql_fetch_array(),将数据库资源类型转换为数组。

4,删除博文页del.php

<?php

include("conn.php");

if(!empty($_GET['del'])){

$d=$_GET['del'],;

$sql="delete from 'news' where 'id'='$d'";

mysql_query;

echo "<scripr>alert; localtion.herf='index.php';</script>";

}

?>

delete from '表名' [where]...,删除sql语句。

}  

?>

5,修改博文页面edit.php

<?php

  include("conn.php");

  if(!empty($_GET['id'])){

  $id=$_GET['id'];

  $sql="select * from 'news' where 'id'=['$id']";

  $query=mysql_query;

  $rs=mysql_fetch_array;

}

  if(!empty($_POST['hid'])){

  $title=$_POST['title'];

  $con=$_POST['contents'];

  $hid=$_POST['hid'];

  $sql="update 'news' set 'title'='$title' 'contents'='$con' where 'id'='$hid' limit 1"

  echo "<script> alert ; location.href='index.php';</script>"

}

?>

<div >

<form action="edit.php" method="post">

<input type="hiden" name="hid" value="<?php echo $rs['id'] ?>">

标题<input type="text" name="title" value="<?php echo $rs['title'] ?>">

内容<textarea rows="5" cols="50" name="con"><?php echo $rs['contents'] ?></textarea><br/>

<input type="submit" name="sub" value="发表">

</form>

</div>

更新指定id的数据,需要获取对应指定id,因此需要设置指定id以供调取。

6,博文页内容view.php

<div class='nav'>

<button><a href="index.php">回到主页</a></button>

</div>

<?php

  include("conn.php");

  

  if(!empty($_GET['id'])){

  $sql="select * from 'news' where 'id'='".$_GET['id']"'";

  $query=mysql_query;

  $rs=mysql_fetch_array;

  $sqlup="update 'news' set hits=hits+1 where 'id'='"._GET['id']."'";

  mysql_query;

}  

?>

<div >

<h1><?php echo $rs['title'] ?></h1>

<span><?php echo $rs['date'] ?></span>

<span>点击量; <?php echo $rs['hits']></span>

</hr>

</p>

</div>```

  

本文由10bet手机官网发布于多线程,转载请注明出处:php之微型博客的创建,WordPress增加文章排序方式

上一篇:基于wordpress主题制作的具体实现步骤,开发者应该留意的WordPress2 下一篇:没有了
猜你喜欢
热门排行
精彩图文