11 May 2012
by kingabirdin php Tags: mysql, php
mysqli提供了面向对象和面向过程两种方式来与数据库交互,分别看一下这两种方式。
1.面向对象
在面向对象的方式中,mysqli被封装成一个类,它的构造方法如下:
__construct ([ string $host [, string $username [, string $passwd [, string $dbnam [, int $port [, string $socket ]]]]]] )
在上述语法中涉及到的参数说明如下。
host:连接的服务器地址。
username:连接数据库的用户名,默认值是服务器进程所有者的用户名。
passwd:连接数据库的密码,默认值为空。
dbname:连接的数据库名称。
port:TCP端口号。
socket:UNIX域socket。
要建立与MySQL的连接可以通过其构造方法实例化mysqli类,例如下面的代码:
<?php
$db_host=”localhost”; //连接的服务器地址
$db_user=”root”; //连接数据库的用户名
$db_psw=”root”; //连接数据库的密码
$db_name=”sunyang”; //连接的数据库名称
$mysqli=new mysqli($db_host,$db_user,$db_psw,$db_name);
?>
mysqli还提供了一个连接MySQL的成员方法connect()。当实例化构造方法为空的mysqli类时,用mysqli对象调用connect()方法同样可连接MySQL,例如,下面的代码:
<?php
$db_host=”localhost”; //连接的服务器地址
$db_user=”root”; //连接数据库的用户名
$db_psw=”root”; //连接数据库的密码
$db_name=”sunyang”; //连接的数据库名称
$mysqli=new mysqli();
$mysqli->connect($db_host,$db_user,$db_psw,$db_name);
?>
关闭与MySQL服务器的连接通过mysqli对象调用close()方法即可,例如:
$mysqli->close();
2.面向过程
在面向过程的方式中,mysqli扩展提供了函数mysqli_connect()与MySQL建立连接,该函数的语法格式如下:
mysqli mysqli_connect ([ string $host [, string $username [, string $passwd
[, string $dbname [, int $port [, string $socket ]]]]]] )
mysqli_connect()函数的用法与mysql扩展中的mysql_connect()函数用法十分相似,下面是mysqli_connect()函数的用法示例:
<?php
$connection = mysqli_connect(“localhost”,”root”,”root”,”sunyang”);
if ( $connection ) {
echo “数据库连接成功”;
}else {
echo “数据库连接失败”;
}
?>
关闭与MySQL服务器的连接使用mysqli_close()函数,例如:
mysqli_close();
3 使用mysqli存取数据
使用mysqli存取数据也包括面向对象和面向过程两种方式,在本节我们只讨论如何使用面向对象的方式来与MySQL交互,关于mysqli扩展中使用面向过程方式这里就不再详细介绍了,有兴趣的读者可参考官方文档来获取相关的资料。
在mysqli中,执行查询使用query()方法,该方法的语法格式如下:
mixed query ( string $query [, int $resultmode ] )
在上述语法中涉及到的参数说明如下。
l query:向服务器发送的SQL语句。
l resultmode:该参数接受两个值,一个是MYSQLI_STORE_RESULT,表示结果作为缓冲集合返回;另一个是MYSQLI_USE_RESULT,表示结果作为非缓冲集合返回。
下面是使用query()方法执行查询的例子:
<?php
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query=”select * from employee”;
$result=$mysqli->query($query);
if ($result) {
if($result->num_rows>0){ //判断结果集中行的数目是否大于0
while($row =$result->fetch_array() ){ //循环输出结果集中的记录
echo ($row[0]).”<br>”;
echo ($row[1]).”<br>”;
echo ($row[2]).”<br>”;
echo ($row[3]).”<br>”;
echo “<hr>”;
}
}
}else {
echo “查询失败”;
}
$result->free();
$mysqli->close();
?>
在上面代码中,num_rows为结果集的一个属性,返回结果集中行的数目。方法fetch_array()将结果集中的记录放入一个数组中并将其返回。最后使用free()方法将结果集中的内存释放,使用close()方法将数据库连接关闭。
对于删除记录(delete)、保存记录(insert)和修改记录(update)的操作,也是使用query()方法来执行的,下面是删除记录的例子:
<?php
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query=”delete from employee where emp_id=2″;
$result=$mysqli->query($query);
if ($result){
echo “删除操作执行成功”;
}else {
echo “删除操作执行失败”;
}
$mysqli->close();
?>
保存记录(insert)、修改记录(update)的操作与删除记录(delete)的操作类似,将SQL语句进行相应的修改即可。
4 预准备语句
使用预准备语句可提高重复使用语句的性能,在PHP中,使用prepare()方法来进行预准备语句查询,使用execute()方法来执行预准备语句。PHP有两种预准备语句:一种是绑定结果,另一种是绑定参数。
(1).绑定结果
所谓绑定结果就是把PHP脚本中的自定义变量绑定到结果集中的相应字段上,这些变量就代表着所查询的记录,绑定结果的示例代码如下:
<?php
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query=”select * from employee”;
$result=$mysqli->prepare($query); //进行预准备语句查询
$result->execute(); //执行预准备语句
$result->bind_result($id,$number,$name,$age); //绑定结果
while ($result->fetch()) {
echo $id;
echo $number;
echo $name;
echo $age;
}
$result->close(); //关闭预准备语句
$mysqli->close(); //关闭连接
?>
在绑定结果的时候,脚本中的变量要与结果集中的字段一一对应,绑定完以后,通过fetch()方法将绑定在结果集中的变量一一取出来,最后将预准备语句和数据库连接分别关闭。
(2).绑定参数
所谓绑定参数就是把PHP脚本中的自定义变量绑定到SQL语句中的参数(参数使用 “?”代替)上,绑定参数使用bind_param()方法,该方法的语法格式如下:
bool bind_param ( string $types , mixed &$var1 [, mixed &$... ] )
在上述语法中涉及到的参数说明如下。
l types:绑定的变量的数据类型,它接受的字符种类包括4个,如表所示。
|
字符种类
|
代表的数据类型
|
|
I
|
integer
|
|
D
|
double
|
|
S
|
string
|
|
B
|
blob
|
参数types接受的字符的种类和绑定的变量需要一一对应。
l var1:绑定的变量,其数量必须要与SQL语句中的参数数量保持一致。
绑定参数的示例代码如下:
<?php
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query=”insert into employee (emp_number,emp_name,emp_age) values (?,?,?)”;
$result=$mysqli->prepare($query);
$result->bind_param(“ssi”,$number,$name,$age); //绑定参数
$number=’sy0807′;
$name=’employee7′;
$age=20;
$result->execute(); //执行预准备语句
$result->close();
$mysqli->close();
?>
在一个脚本中还可以同时绑定参数和绑定结果,示例代码如下:
<?php
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query=”select * from employee where emp_id < ?”;
$result=$mysqli->prepare($query);
$result->bind_param(“i”,$emp_id); //绑定参数
$emp_id=4;
$result->execute();
$result->bind_result($id,$number,$name,$age); //绑定结果
while ($result->fetch()) {
echo $id.”<br>”;
echo $number.”<br>”;
echo $name.”<br>”;
echo $age.”<br>”;
}
$result->close();
$mysqli->close();
?>
5 多个查询
mysqli扩展提供了能连续执行多个查询的multi_query()方法,该方法的语法格式如下:
bool mysqli_multi_query ( mysqli $link , string $query )
在执行多个查询时,除了最后一个查询语句,每个查询语句之间要用“;”分开。执行多个查询的示例代码如下:
$mysqli=new mysqli(“localhost”,”root”,”root”,”sunyang”); //实例化mysqli
$query = “select emp_name from employee ;”;
$query .= “select dep_name from depment “;
if ($mysqli->multi_query($query)) { //执行多个查询
do {
if ($result = $mysqli->store_result()) {
while ($row = $result->fetch_row()) {
echo $row[0];
echo “<br>”;
}
$result->close();
}
if ($mysqli->more_results()) {
echo (“—————–<br>”); //连个查询之间的分割线
}
} while ($mysqli->next_result());
}
$mysqli->close();//关闭连接
?>
在上述代码中,store_result()方法用于获得一个缓冲结果集; fetch_row()方法的作用类似于fetch_array()方法;more_results()方法用于从一个多查询中检查是否还有更多的查询结 果;next_result()方法用于从一个多查询中准备下一个查询结果。
- 来源:转载
- 原作者:佚名 -
- 版权声明:欢迎转载,但请以连接方式备注出处、作者。
- 本文链接地址:http://www.lao8.org/html/8/2011-2-22/php_MySQLi.html
- 文章名:PHP5 mysqli 教程
13 Apr 2012
by kingabirdin Desgin
simple as love, strong as love.’ 这是设计师的设计理念,这是 ‘seoul cycle design 2010′ 伊朗的入围作品,用自行车到处印上你爱的印迹
13 Apr 2012
by kingabirdin Desgin

紧凑的生活空间越来越不能满足我们把高大的书柜搬进家中,而放在角落里的普通小书架又因为高度问题往往给我们查找书目带来不便,每次都要弯着腰或低下头来查看,如果家里有喜欢阅读的老人来说,每次弯腰都存在着潜在的危险。
不过今天《Deram ZAKKA设计志》给大家带来的这款倒三角形状书架,书本斜放在上面正好明显露出书脊,无论你是站着还是坐着,都可以清晰的看到书名,真正让你查找书目变得更加省心。加上天然桦木所制,手工切割工艺也使得这个书架增添了许多温存的气息。另外它采用了天然蜂蜡来覆盖表层,在阳光的照射下更显幽静,对于家居装饰而言也是上乘之作。link
原文:DREAM ZAKKA设计志
11 Apr 2012
by kingabirdin Desgin
The Best of News Design 书上的一款设计,手机拍的图片效果有点差。

10 Apr 2012
by kingabirdin Linux
进入 vi 的命令
vi filename :打开或新建文件,并将光标置于第一行首
vi +n filename :打开文件,并将光标置于第n行首
vi + filename :打开文件,并将光标置于最后一行首
vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处
vi -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename
vi filename….filename :打开多个文件,依次进行编辑 光标控制命令
命令 光标移动
h或^h 向左移一个字符
j或^j或^n 向下移一行
k或^p 向上移一行
l或空格 向右移一个字符
G 移到文件的最后一行
nG 移到文件的第n行
w 移到下一个字的开头
W 移到下一个字的开头,忽略标点符号
b 移到前一个字的开头
B 移到前一个字的开头,忽略标点符号
L 移到屏幕的最后一行
M 移到屏幕的中间一行
H 移到屏幕的第一行
e 移到下一个字的结尾
E 移到下一个字的结尾,忽略标点符号
( 移到句子的开头
) 移到句子的结尾
{ 移到段落的开头
} 移到下一个段落的开头
0或| 移到当前行的第一列
n| 移到当前行的第n列
^ 移到当前行的第一个非空字符
$ 移到当前行的最后一个字符
+或return 移到下一行的第一个字符
- 移到前一行的第一个非空字符
屏幕翻滚类命令
Ctrl+u:向文件首翻半屏
Ctrl+d:向文件尾翻半屏
Ctrl+f:向文件尾翻一屏
Ctrl+b;向文件首翻一屏
nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。
在vi中添加文本
命令 插入动作
a 在光标后插入文本
A 在当前行插入文本
i 在光标前插入文本
I 在当前行前插入文本
o 在当前行的下边插入新行
O 在当前行的上边插入新行
:r file 读入文件file内容,并插在当前行后
:nr file 读入文件file内容,并插在第n行后
escape 回到命令模式
^v char 插入时忽略char的指定意义,这是为了插入特殊字符
在vi中删除文本
命令 删除操作
x 删除光标处的字符,可以在x前加上需要删除的字符数目
nx 从当前光标处往后删除n个字符
X 删除光标前的字符,可以在X前加上需要删除的字符数目
nX 从当前光标处往前删除n个字符
dw 删至下一个字的开头
ndw 从当前光标处往后删除n个字
dG 删除行,直到文件结束
dd 删除整行
ndd 从当前行开始往后删除
db 删除光标前面的字
ndb 从当前行开始往前删除n字
:n,md 从第m行开始往前删除n行
d或d$ 从光标处删除到行尾
dcursor_command 删除至光标命令处,如dG将从当产胆行删除至文件的末尾
^h或backspace 插入时,删除前面的字符
^w 插入时,删除前面的字
修改vi文本
每个命令前面的数字表示该命令重复的次数
命令 替换操作
rchar 用char替换当前字符
R text escape 用text替换当前字符直到换下Esc键
stext escape 用text代替当前字符
S或cctext escape 用text代替整行
cwtext escape 将当前字改为text
Ctext escape 将当前行余下的改为text
cG escape 修改至文件的末尾
ccursor_cmd text escape 从当前位置处到光标命令位置处都改为text
在vi中查找与替换
命令 查找与替换操作
/text 在文件中向前查找text
?text 在文件中向后查找text
n 在同一方向重复查找
N 在相反方向重复查找
ftext 在当前行向前查找text
Ftext 在当前行向后查找text
ttext 在当前行向前查找text,并将光标定位在text的第一个字符
Ttext 在当前行向后查找text,并将光标定位在text的第一个字符
:set ic 查找时忽略大小写
:set noic 查找时对大小写敏感
:s/oldtext/newtext 用newtext替换oldtext
:m,ns/oldtext/newtext 在m行通过n,用newtext替换oldtext
& 重复最后的:s命令
:g/text1/s/text2/text3 查找包含text1的行,用text3替换text2
:g/text/command 在所有包含text的行运行command所表示的命令
:v/text/command 在所有不包含text的行运行command所表示的命令
在vi中复制文本
命令 复制操作
yy 将当前行的内容放入临时缓冲区
nyy 将n行的内容放入临时缓冲区
p 将临时缓冲区中的文本放入光标后
P 将临时缓冲区中的文本放入光标前
dsfsd "(a-z)nyy 复制n行放入名字为圆括号内的可命名缓冲区,省略n表示当前行
"(a-z)ndd 删除n行放入名字为圆括号内的可命名缓冲区,省略n表示当前行
"(a-z)p 将名字为圆括号的可命名缓冲区的内容放入当前行后
"(a-z)P 将名字为圆括号的可命名缓冲区的内容放入当前行前
在vi中撤消与重复
命令 撤消操作
u 撤消最后一次修改
U 撤消当前行的所有修改
. 重复最后一次修改
, 以相反的方向重复前面的f、F、t或T查找命令
; 重复前面的f、F、t或T查找命令
"np 取回最后第n次的删除(缓冲区中存有一定次数的删除内容,一般为9)
n 重复前面的/或?查找命令
N 以相反方向重复前面的/或?命令
保存文本和退出vi
命令 保存和/或退出操作
:w 保存文件但不退出vi
:w file 将修改保存在file中但不退出vi
:wq或ZZ或:x 保存文件并退出vi
:q! 不保存文件,退出vi
:e! 放弃所有修改,从上次保存文件开始再编辑
vi中的选项
选项 作用
:set all 打印所有选项
:set nooption 关闭option选项
:set nu 每行前打印行号
:set showmode 显示是输入模式还是替换模式
:set noic 查找时忽略大小写
:set list 显示制表符(^I)和行尾符号
:set ts=8 为文本输入设置tab stops
:set window=n 设置文本窗口显示n行
vi的状态
选项 作用
:.= 打印当前行的行号
:= 打印文件中的行数
^g 显示文件名、当前的行号、文件的总行数和文件位置的百分比
:l 使用字母"l"来显示许多的特殊字符,如制表符和换行符
在文本中定位段落和放置标记
选项 作用
{ 在第一列插入{来定义一个段落
[[ 回到段落的开头处
]] 向前移到下一个段落的开头处
m(a-z) 用一个字母来标记当前位置,如用mz表示标记z
'(a-z) 将光标移动到指定的标记,如用'z表示移动到z
在vi中连接行
选项 作用
J 将下一行连接到当前行的末尾
nJ 连接后面n行
光标放置与屏幕调整
选项 作用
H 将光标移动到屏幕的顶行
nH 将光标移动到屏幕顶行下的第n行
M 将光标移动到屏幕的中间
L 将光标移动到屏幕的底行
nL 将光标移动到屏幕底行上的第n行
^e(ctrl+e) 将屏幕上滚一行
^y 将屏幕下滚一行
^u 将屏幕上滚半页
^d 将屏幕下滚半页
^b 将屏幕上滚一页
^f 将屏幕下滚一页
^l 重绘屏幕
z-return 将当前行置为屏幕的顶行
nz-return 将当前行下的第n行置为屏幕的顶行
z. 将当前行置为屏幕的中央
nz. 将当前行上的第n行置为屏幕的中央
z- 将当前行置为屏幕的底行
nz- 将当前行上的第n行置为屏幕的底行
vi中的shell转义命令
选项 作用
:!command 执行shell的command命令,如:!ls
:!! 执行前一个shell命令
:r!command 读取command命令的输入并插入,如:r!ls会先执行ls,然后读入内容
:w!command 将当前已编辑文件作为command命令的标准输入并执行command命令,如:w!grep all
:cd directory 将当前工作目录更改为directory所表示的目录
:sh 将启动一个子shell,使用^d(ctrl+d)返回vi
:so file 在shell程序file中读入和执行命令
vi中的宏与缩写
(避免使用控制键和符号,不要使用字符K、V、g、q、v、*、=和功能键)
选项 作用
:map key command_seq 定义一个键来运行command_seq,如:map e ea,无论什么时候都可以e移到一个字的末尾来追加文本
:map 在状态行显示所有已定义的宏
:umap key 删除该键的宏
:ab string1 string2 定义一个缩写,使得当插入string1时,用string2替换string1。当要插入文本时,键入string1然后按Esc键,系统就插入了string2
:ab 显示所有缩写
:una string 取消string的缩写
在vi中缩进文本
选项 作用
^i(ctrl+i)或tab 插入文本时,插入移动的宽度,移动宽度是事先定义好的
:set ai 打开自动缩进
:set sw=n 将移动宽度设置为n个字符
n<< 使n行都向左移动一个宽度
n>> 使n行都向右移动一个宽度,例如3>>就将接下来的三行每行都向右移动一个移动宽度
04 Jan 2012
by kingabirdin Live
新的一年,买了一个新域名 kingabird.me
原来的 kingabird.com 域名到期没有续费,被「别有用心」的人给抢去了。
在这个人人微博的时候,重新开始写点 Blog,写点东西。
不知道能坚持多久。
08 Sep 2009
by kingabirdin JavaScript
拿到这本《JavaScript DOM 编程艺术》的书已经快过去半年,之前读过一遍后,就丢掉一边了,内容很简单,当初很适合我这种初学都使用(现在也依然是初学者),前几天又重新翻了一遍,使本来有些模糊的概念重新又清晰了起来。看来还是很有必要“温故而知新”的。现在进入正题……
说白了,JavaScript 对于实现网页中的各种效果都是通过控制 DOM 来实现的,这应该是这本书要讲的核心内容。
所谓 DOM,是英文 Document Object Model 的首字母缩写,中文可以译作“文档对象模型”。
Document ( 文档 ) 是一切开始的基本,没有 Document 也就无从谈起 DOM。
Object ( 对象 ) 所指的是 JavaScript 的对象,本书大部分只讨论 document 对象的属性和方法。
Model ( 模型 ) 就是网站内容的表现形式,网页当前代码的结构。
DOM 代表着被加载到浏览器窗口里的当前网页,浏览器向我们提供了当前网页的地图(或者说模型),而我们可以通过 JavaScript 去读取这张地图。
如何通过 JavaScript 控制 DOM 呢?
其实讲起来理论很简单
1. 查找网页中要修改的元素节点。
2. 然后能过各种方法进行操作(包括添加,修改,删除)
现在来说上面提到的第一点
查找网页中的目标元素
方法有 getElementById , getElementsByTagName , 这也是 DOM 操作中很重要的两个方法。这两个方法的具体使用方法请在 google 中自己搜索。(请注意 JavaScript 语言是区分大小写的,所以写成 GetElementById 或者 getElementbyid 是不行的。 )
现在来说上面提到的第二点
操作网页中的 DOM 的元素,这个地方还是用实例的方法比较好说
例一:在页面中添加元素
var example = document.getElementById( “example ” ); // 查找页面中 id 为 example 的元素节点。
var p = document.createElement(“p”); // 创建一个 p 元素。
var text = document.createTextNode(“这里是要添加的文本”); // 创建添加文本
p.appendChild( text ); // 将 text 文本添加到 p 元素里
example.appendChild( p ); // 将 p 元素添加到 id 为 example 的元素中
然后执行此函数就可以了。
例二:通过获取页面中目标元素的属性值并把该值赋予其它元素的方法来实现页面元素的修改
var example = document.getElementById( “example ” );
var example_a = example.document.getElementsByTagName( “a” ); // 获取页面中 id 为 example 的元素节点里的链接元素。
var link = example_a.getAttribute(“href”); // 获取目标元素的 href 值,也就是链接地址。
var holder = document.getElementById( “holder” ); // 获取页面中 id 为 holder 的元素节点
holder.setAttribute( “href”,link ); // 将 link 通过 setAttribute 方法赋予 holder 的 href 属性
更多 DOM 操作,请 点击 这里。
17 Aug 2009
by kingabirdin HTML/CSS
block-level elements (块级元素)
inline elements (内联元素)
所有允许被 BODY 元素包含的元素,要么是块级的;要么是内联的;要么既可以算作块级的,也可以算作内联的。但是绝对不存在一个能被BODY包含,但即非块级,又非内联的元素。
更直白点说块级元素就是元素本身会占据一个矩形的位置,是一个 box,默认一个块级元素会占用一行的位置,而内联元素是只在一行内占据一个或者几个字符的位置。
块级元素实例
<div>这里是测试文本</div>
内联元素实例
<div>这里是测试文本<span>这里是内联样式的文本</span></div>
常见的块级元素有 DIV, FORM, TABLE, P, PRE, H1~H6, DL, OL, UL 等等。
常见的内联元素有 SPAN, A, STRONG, EM, LABEL, INPUT, SELECT, TEXTAREA, IMG, BR 等等。
另外,SCRIPT, OBJECT, MAP, BUTTON, DEL, INS 这些元素,既可以作为块级元素,也可以作为内联元素。
06 Jul 2009
by kingabirdin php
这句是用来读取WordPress后台设定的作者昵称,如果不愿意使用昵称而要使用名字,也可以使用其它函数:the_author显示作者名字;the_author_login显示作者登录名;the_author_url显示作者的网站地址。
显示发布时间
显示文章分类。
如果作者就是博客管理员,则会在登录状态下显示edit编辑按钮
the_author 显示文章的作者
the_author_description 显示文章作者的描述(作者个人资料中的描述)
the_author_login 显示文章作者的登录名
the_author_firstname 显示文章作者的firstname(名)
the_author_lastname 显示文章作者的lastname(姓)
the_author_nickname 显示文章作者的昵称
the_author_ID 显示文章作者的ID号
the_author_email 显示文章作者的电子邮箱
the_author_url 显示文章作者的网站地址
the_author_link (添加于2.1版本) 显示一个以文章作者名为链接名,链接地址为文章作者的网址的链接。
the_author_icq (不推荐使用) 显示文章作者的icq
the_author_aim 显示文章作者的aim
the_author_yim 显示文章作者的yim
the_author_msn (不推荐使用) 显示文章作者的msn
the_author_posts 显示文章作者已发表文章的篇数
the_author_posts_link 显示一个链接到文章作者已发表文章列表的链接
list_authors (不推荐使用) 显示blog所有作者和他们的相关信息。完整函数如下:
参数:
optioncount:是否显示各作者已发表文章的篇数,可选值为:TRUE 和 FALSE(默认值)
exclude_admin:是否不列出管理员,可选值为:TRUE(默认值) 和 FALSE
show_fullname :是否显示各作者的全名,可选值为:TRUE 和 FALSE(默认值)
hide_empty:是否不显示发表文章数为0的作者,可选值为:TRUE(默认值) 和 FALSE
feed:链接到各个作者发表文章的RSS供稿种子链接名,默认为空,不显示RSS供稿种子
feed_image:供稿种子的图片地址,如果提供此项,则覆盖上面的feed,默认为空
例如:
代表不显示各个作者的发布文章数,列出管理员,显示各作者的全名,显示发布文章数为0的作者和不显示RSS供稿种子。
wp_list_authors 显示blog作者列表,如果作者发表过文章,则他的名字将链接到他发表的文章列表中。可定义是否显示其他信息。
参数:
optioncount:是否显示各个作者发表文章数,可选值:true 和 false(默认值)
exclude_admin:是否不显示“admin”用户,可选值:true(默认值) 和 false
show_fullname:是否显示各个作者的全名,如果不显示,将显示昵称。可选值:true 和 false(默认值)
hide_empty:是否不显示发表文章数为0的作者,可选值:true(默认值) 和 false
feed:链接到各个作者发表文章的RSS供稿种子链接名,默认为空,不显示RSS供稿种子
feed_image:供稿种子的图片地址,如果提供此项,则覆盖上面的feed,默认为空
例如:
原文地址:http://kingabird.com/wp-admin/post-new.php
Recent Comments