日志列表
RSS我们先来看一段代码
$str = 'aaaaa'; $a = &$str; $str = 'zzz'; unset($str); echo $a;
这个代码一看觉得$a的值为null,但实际值为zzz
仔细看了手册后发现
当 unset 一个引用,只是断开了变量名和变量内容之间的绑定。这并不意味着变量内容被销毁了
看到这段后就不难理解了,这段代码unset掉的只是断开了str与其值间的绑定而已。
我用到的几个火狐插件
1.ColorZilla 先进的鼠标点选器,颜色选择器,页面缩放和其它有意思的东西
2.CSSViewer 查看CSS样式
3.Firebug 小小萤火虫,功能却很全,太方便了,我们这些做前端开发的人员可享福吧。有DOM查看,js调试,css调试等等一系列的工具
4.Web Developer Web Developer 插件强大的功能超乎你的想象,用于CSS网页布局开发调试只是它强大功能的一部分,对于网络程序的开发也提供了非常强大的辅助设计功能,我们不将它完全的展开探讨,我们仅针对CSS网页布局开发调试对它进行了解,有兴趣的朋友可以详细的研究一下它的强大功能。CSS工具是我们需要了解的重点,它提供了许
多功能来辅助我们查看网页
5.Fast Dial 可以像 Opera 浏览器的Speed dial 一样,让你通过点击缩略图快速访问常用的网站
6.Fasterfox 火狐忧化插件
7.FireFTP
8.FireGestures 用鼠标手势执行命令
9.Fission 在地址樯显示载入进度条
10.Flagfox 显示描述当前服务器位置的国旗
11.Forecastfox 在状态栏显示现在天气以及未来几天的天气预报
12.FoxTab 页面切换绚丽的3D效果
13.IE Tab 让Firefox也能内嵌IE用双核心
14.Screengrab 一个非常好用的截图插件 能随心所欲的截取你想要的部分和保存整个网页图片
15.SearchStatus 站火狐显示Alexa排名和PR值
16.ShowIP 显示当前网页的IP
php 不使用第三方变量和数组交换两个变量的值
今天去面试有一道题,怎样不用第三方变量和数组交换二个变量的值,在那里想了半天也没想出么样实现-_-!!,回来后查了下资料,可以用位运算中的异或运算。
下面是试例代码
<?php $a = 'str1'; $b = 'str2'; echo "交换前:\$a = {$a}; \$b = {$b};"; $b = $b ^ $a; $a = $b ^ $a; $b = $b ^ $a; echo "交换后:\$a = {$a}; \$b = {$b};"; ?>
此算法能够实现是由异或运算的特点决定的,通过异或运算能够使数据中的某些位翻转,其他位不变。这就意味着任意一个数与任意一个给定的值连续异或两次,值不变。
连续二十来天的阴雨天终于结束了,但我内心的阴雨天却来临了,我们失业了,在这个形式不太好的09年的春天。
这一切都来得太突然了,不知是因为失业的伤心还是因为分开的依依不舍,心里有一种很强的失落感。
怀念这短短三个月来和同事在一起的日子,真的很开心,这段时间好像就是一个梦,现在梦醒了。
希望我和其它同事一样早日找到新的工作
技术部全体合影

静态调用的成员一定要定义成 static (PHP5 ONLY)
贴士:PHP 5 引入了静态成员的概念,作用和 PHP 4 的函数内部静态变量一致,但前者是作为类的成员来使用。静态变量和 Ruby 的类变量(class variable)差不多,所有类的实例共享同一个静态变量。
<?php class foo { function bar() { echo 'foobar'; } } $foo = new foo; // instance way $foo->bar(); // static way foo::bar(); ?>
静态地调用非 static 成员,效率会比静态地调用 static 成员慢 50-60%。主要是因为前者会产生 E_STRICT 警告,内部也需要做转换。
使用类常量 (PHP5 ONLY)
贴士:PHP 5 新功能,类似于 C++ 的 const。
使用类常量的好处是:
- 编译时解析,没有额外开销
- 杂凑表更小,所以内部查找更快
- 类常量仅存在于特定「命名空间」,所以杂凑名更短
- 代码更干净,使除错更方便
(暂时)不要使用 require/include_once
require/include_once 每次被调用的时候都会打开目标文件!
- 如果用绝对路径的话,PHP 5.2/6.0 不存在这个问题
- 新版的 APC 缓存系统已经解决这个问题
文件 I/O 增加 => 效率降低
如果需要,可以自行检查文件是否已被 require/include。
不要调用毫无意义的函数
有对应的常量的时候,不要使用函数。
<?php php_uname('s') == PHP_OS; php_version() == PHP_VERSION; php_sapi_name() == PHP_SAPI; ?>
虽然使用不多,但是效率提升大概在 3500% 左右。
最快的 Win32 检查
<?php $is_win = DIRECTORY_SEPARATOR == '\\'; ?>
- 不用函数
- Win98/NT/2000/XP/Vista/Longhorn/Shorthorn/Whistler…通用
- 一直可用
时间问题 (PHP>5.1.0 ONLY)
你如何在你的软件中得知现在的时间?简单,「time() time() again, you ask me…」。
不过总归会调用函数,慢。
现在好了,用 $_SERVER['REQUEST_TIME'],不用调用函数,又省了。
加速 PCRE
- 对于不用保存的结果,不用 (),一律用 (?:)
这样 PHP 不用为符合的内容分配内存,省。效率提升 15% 左右。
- 能不用正则,就不用正则,在分析的时候仔细阅读手册「字符串函数」部分。有没有你漏掉的好用的函数?
例如:
strpbrk() strncasecmp() strpos()/strrpos()/stripos()/strripos()
加速 strtr
如果需要转换的全是单个字符的时候,用字符串而不是数组来做 strtr:
<?php $addr = strtr($addr, "abcd", "efgh"); // good $addr = strtr($addr, array('a' => 'e', // ... )); // bad ?>
效率提升:10 倍。
不要做无谓的替换
即使没有替换,str_replace 也会为其参数分配内存。很慢!解决办法:
- 用 strpos 先查找(非常快),看是否需要替换,如果需要,再替换
效率:
- 如果需要替换:效率几乎相等,差别在 0.1% 左右。
- 如果不需要替换:用 strpos 快 200%。
邪恶的 @ 操作符
不要滥用 @ 操作符。虽然 @ 看上去很简单,但是实际上后台有很多操作。用 @ 比起不用 @,效率差距:3 倍。
特别不要在循环中使用 @,在 5 次循环的测试中,即使是先用 error_reporting(0) 关掉错误,在循环完成后再打开,都比用 @ 快。
善用 strncmp
当需要对比「前 n 个字符」是否一样的时候,用 strncmp/strncasecmp,而不是 substr/strtolower,更不是 PCRE,更千万别提 ereg。strncmp/strncasecmp 效率最高(虽然高得不多)。
慎用 substr_compare (PHP5 ONLY)
按照上面的道理,substr_compare 应该比先 substr 再比较快咯。答案是否定的,除非:
- 无视大小写的比较
- 比较较大的字符串
不要用常量代替字符串
为什么:
- 需要查询杂凑表两次
- 需要把常量名转换为小写(进行第二次查询的时候)
- 生成 E_NOTICE 警告
- 会建立临时字符串
效率差别:700%。
不要把 count/strlen/sizeof 放到 for 循环的条件语句中
贴士:我的个人做法
<?php for ($i = 0, $max = count($array);$i < $max; ++$i); ?> 效率提升相对于: - count 50% - strlen 75% <strong>短的代码不一定快 </strong> <pre lang="php"> <?php // longest if ($a == $b) { $str .= $a; } else { $str .= $b; } // longer if ($a == $b) { $str .= $a; } $str .= $b; // short $str .= ($a == $b ? $a : $b); ?>
你觉得哪个快?
效率比较:
- longest: 4.27
- longer: 4.43
- short: 4.76
不可思议?再来一个:
<?php // original $d = dir('.'); while (($entry = $d->read()) !== false) { if ($entry == '.' || $entry == '..') { continue; } } // versus glob('./*'); // versus (include . and ..) scandir('.'); ?>
哪个快?
效率比较:
- original: 3.37
- glob: 6.28
- scandir: 3.42
- original without OO: 3.14
- SPL (PHP5): 3.95
画外音:从此也可以看出来 PHP5 的面向对象效率提高了很多,效率已经和纯函数差得不太多了。
提高 PHP 文件访问效率
需要包含其他 PHP 文件的时候,使用完整路径,或者容易转换的相对路径。
<?php include 'file.php'; // bad approach incldue './file.php'; // good include '/path/to/file.php'; // ideal ?>
物尽其用
PHP 有很多扩展和函数可用,在实现一个功能的之前,应该看看 PHP 是否有了这个功能?是否有更简单的实现?
<?php $filename = "./somepic.gif"; $handle = fopen($filename, "rb"); $contents = fread($handle, filesize($filename)); fclose($handle); // vs. much simpler file_get_contents('./somepic.gif'); ?>
关于引用的技巧
引用可以:
- 简化对复杂结构数据的访问
- 优化内存使用
<?php $a['b']['c'] = array(); // slow 2 extra hash lookups per access for ($i = 0; $i < 5; ++$i) $a['b']['c'][$i] = $i; // much faster reference based approach $ref =& $a['b']['c']; for ($i = 0; $i < 5; ++$i) $ref[$i] = $i; ?> <?php $a = 'large string'; // memory intensive approach function a($str) { return $str.'something'; } // more efficient solution function a(&$str) { $str .= 'something'; } ?>
==============================================
参考资料
http://ilia.ws
Ilia 的个人网站,Blog,他参与的开发以及出版的一些稿物链接等等。
http://ez.no
eZ components 官方网站,eZ comp 是针对 PHP5 的开源通用库,以效率为己任,Ilia 也参与了开发。
http://phparch.com
php|architect,不错的 php 出版商/培训组织。买不起或者买不到的话,网上可以下到很多经典的盗版。
http://talks.php.net
PHP 会议上的演讲合集,现在还不是很丰富,不过内容都是让人一看就容易废寝忘食的好东东,推荐早上睡眼朦胧的时候或者吃完午饭仔细研究,否则你会忘记吃饭和睡觉的!
==============================================
第一讲:
1. 光标在屏幕文本中的移动既可以用箭头键,也可以使用 hjkl 字母键。
h (左移) j (下行) k (上行) l (右移)
2. 欲进入vim编辑器(从命令行提示符),请输入∶vim 文件名 <回车>
3. 欲退出vim编辑器,请输入以下命令放弃所有修改∶
或者输入以下命令保存所有修改∶
4. 在正常模式下删除光标所在位置的字符,请按∶ x
5. 在正常模式下要在光标所在位置开始插入文本,请按∶
i 输入必要文本
特别提示∶按下
的命令。
第二讲:
1. 欲从当前光标删除至单字/单词末尾,请输入∶dw
2. 欲从当前光标删除至当前行末尾,请输入∶d$
3. 欲删除整行,请输入∶dd
4. 在正常模式下一个命令的格式是∶
[number] command object 或者 command [number] object
其意是∶
number – 代表的是命令执行的次数
command – 代表要做的事情,比如 d 代表删除
object – 代表要操作的对象,比如 w 代表单字/单词,$ 代表到行末等等。
$ (to the end of line), etc.
5. 欲撤消以前的操作,请输入∶u (小写的u)
欲撤消在一行中所做的改动,请输入∶U (大写的U)
欲撤消以前的撤消命令,恢复以前的操作结果,请输入∶CTRL-R
第三讲:
1. 要重新置入已经删除的文本内容,请输入小写字母 p。该操作可以将已删除
的文本内容置于光标之后。如果最后一次删除的是一个整行,那么该行将置
于当前光标所在行的下一行。
2. 要替换光标所在位置的字符,请输入小写的 r 和要替换掉原位置字符的新字
符即可。
3. 更改类命令允许您改变指定的对象,从当前光标所在位置直到对象的末尾。
比如输入 cw 可以替换当前光标到单词的末尾的内容;输入 c$ 可以替换当
前光标到行末的内容。
4. 更改类命令的格式是∶
[number] c object 或者 c [number] object
第四讲:
1. Ctrl-g 用于显示当前光标所在位置和文件状态信息。Shift-G 用于将光标跳
转至文件最后一行。先敲入一个行号然后按 Shift-G 则是将光标移动至该行
号代表的行。
2. 输入 / 然后紧随一个字符串是则是在当前所编辑的文档中向后查找该字符串。
输入问号 ? 然后紧随一个字符串是则是在当前所编辑的文档中向前查找该字
符串。完成一次查找之后按 n 键则是重复上一次的命令,可在同一方向上查
找下一个字符串所在;或者按 Shift-N 向相反方向查找下该字符串所在。
3. 如果光标当前位置是括号(、)、[、]、{、},按 % 可以将光标移动到配对的
括号上。
4. 在一行内替换头一个字符串 old 为新的字符串 new,请输入 :s/old/new
在一行内替换所有的字符串 old 为新的字符串 new,请输入 :s/old/new/g
在两行内替换所有的字符串 old 为新的字符串 new,请输入 :#,#s/old/new/g
在文件内替换所有的字符串 old 为新的字符串 new,请输入 :%s/old/new/g
进行全文替换时询问用户确认每个替换需添加 c 选项,请输入 :%s/old/new/gc
第五讲:
1.:!command 用于执行一个外部命令 command。
请看一些实际例子∶
:!dir – 用于显示当前目录的内容。
:!rm FILENAME – 用于删除名为 FILENAME 的文件。
2. :w FILENAME 可将当前 VIM 中正在编辑的文件保存到名为 FILENAME 的文
件中。
3. :#,#w FILENAME 可将当前编辑文件第 # 行至第 # 行的内容保存到文件
FILENAME 中。
4. :r FILENAME 可提取磁盘文件 FILENAME 并将其插入到当前文件的光标位置
后面。
第六讲:
1. 输入小写的 o 可以在光标下方打开新的一行并将光标置于新开的行首,进入
插入模式。
输入大写的 O 可以在光标上方打开新的一行并将光标置于新开的行首,进入
插入模式。
2. 输入小写的 a 可以在光标所在位置之后插入文本。
输入大写的 A 可以在光标所在行的行末之后插入文本。
3. 输入大写的 R 将进入替换模式,直至按
模式。
4. 输入 :set xxx 可以设置 xxx 选项。
例如:
:set ic (ic就是英文忽略大小写Ignore Case的首字母缩写词).
第七讲:
** 使用在线帮助系统 **
Vim 拥有一个细致全面的在线帮助系统。要启动该帮助系统,请选择如下三种方
法之一∶
– 按下
– 按下
– 输入 :help <回车>
输入 :q <回车> 可以关闭帮助窗口。
提供一个正确的参数给”:help”命令,您可以找到关于该主题的帮助。请试验以
下参数(可别忘了按回车键哦。:)∶
:help w <回车>
:help c_
:help insert-index <回车>
:help user-manual <回车>
第八讲:
** 创建一个启动脚本 启用vim的功能 **
Vim的功能特性要比vi多得多,但大部分功能都没有缺省激活。为了启动更多的
功能,您得创建一个vimrc文件。
1. 开始编辑vimrc文件,这取决于您所使用的操作系统∶
:edit ~/.vimrc 这是Unix系统所使用的命令
:edit $VIM/_vimrc 这是Windows系统所使用的命令
2. 接着导入vimrc范例文件∶
:read $VIMRUNTIME/vimrc_example.vim
3. 保存文件,命令为∶
:write
在下次您启动vim的时候,编辑器就会有了语法高亮的功能。您可以继续把您喜
欢的其它功能设置添加到这个vimrc文件中。
一个比较好用的PHP分页类
/** * 分页类 * * @package pager * @author Veidy.lei<veidy .lei@gmail.com> * @version $Id: pager.php,v 1.5 2008/03/26 09:26:39 Veidy.lei Exp $ * @copyright (c) 2008 Veidy.lei Group */ class pager { var $page_num_per_group = 3; //页码每组页码数 var $total_item = 0; //总记录数 var $per_page_num = 10; //每页记录数 var $first_page_num = 1; //首页页码数 var $pre_page_num = 0; //上页页码数 var $next_page_num = 0; //下页页码数 var $last_page_num = 0; //尾页页码数 var $pre_group_page_num = 0; //上一组的显示页码数 var $next_group_page_num = 0; //下一组的显示页码数 var $cur_group_page = array(); //当前组的页面页码数列表 var $cur_page = 1; //当前页码数 var $cur_group = 0; //当前组 var $total_group = 0; //总组数 var $page_num = array(); //所有页码 var $total_page = 0; //总页数 var $cur_item_num = 0; //当前页记录条数 function pager($total_item = 0, $per_page_num = 10, $page_num_per_group = 3) { $this->cur_page = (int)request_var('page', 1); //得到当前页码数 $this->per_page_num = ($per_page_num > 0) ? ceil($per_page_num) : 10; //得到每页记录数 $this->page_num_per_group = ($page_num_per_group > 0) ? ceil($page_num_per_group) : 3; //得到页码每组页码数 if ($total_item < 1) { $this->page_num = false; //即无分页 } else { $this->total_item = $total_item; $this->total_page = ceil($this->total_item / $this->per_page_num); //得到总页数 $this->last_page_num = $this->total_page; //得到尾页页码数 if ($this->cur_page < 1) { $this->cur_page = 1; //得到当前页码数 } if ($this->cur_page > $this->total_page) { $this->cur_page = $this->total_page; //得到当前页码数 } $this->pre_page_num = ($this->cur_page > 1) ? $this->cur_page - 1 : 1; //得到上页页码数 $this->next_page_num = ($this->cur_page < $this->total_page) ? $this->cur_page + 1 : $this->total_page; //得到下页页码数 $this->total_group = ceil($this->total_page / $this->page_num_per_group); //得到总组数 $this->cur_group = ceil($this->cur_page / $this->page_num_per_group); //得到当前组数 if ($this->total_group > 1) { if ($this->cur_group > 1) //当前组不是第一组 { $this->pre_group_page_num = ($this->cur_group - 1) * $this->page_num_per_group; //得到上一组的显示页码数 } if ($this->cur_group < $this->total_group) //当前组不是最后一组 { $this->next_group_page_num = ($this->cur_group * $this->page_num_per_group) + 1; //得到下一组的显示页码数 } } $this->cur_group_page[0] = (($this->cur_group - 1) * $this->page_num_per_group) + 1; //当前组第一页 for ($i = 1; $i < $this->page_num_per_group; $i++) { if ($this->cur_group_page[0] <= ($this->total_page - $i)) { $this->cur_group_page[$i] = $this->cur_group_page[0] + $i; //当前组其它页 } } if ($this->cur_page == $this->total_page) { $this->cur_item_num = $this->total_item - (($this->total_page -1) * $this->per_page_num); } else { $this->cur_item_num = $this->per_page_num; } $this->page_num = array(); $this->page_num['total_item'] = $this->total_item; $this->page_num['page_num_per_group'] = $this->page_num_per_group; $this->page_num['per_page_num'] = $this->per_page_num; $this->page_num['first_page_num'] = $this->first_page_num; $this->page_num['pre_page_num'] = $this->pre_page_num; $this->page_num['next_page_num'] = $this->next_page_num; $this->page_num['last_page_num'] = $this->last_page_num; $this->page_num['pre_group_page_num'] = $this->pre_group_page_num; $this->page_num['next_group_page_num'] = $this->next_group_page_num; $this->page_num['cur_group_page'] = $this->cur_group_page; $this->page_num['cur_page'] = $this->cur_page; $this->page_num['cur_group'] = $this->cur_group; $this->page_num['total_group'] = $this->total_group; $this->page_num['total_page'] = $this->total_page; $this->page_num['cur_item_num'] = $this->cur_item_num; } } /** * 获取各相关页码数 * * @return bool 或 array ,如果是false表示无记录,如果是数组,返回值如下: * $this->page_num['total_item']--------------------------------总记录条数 $this->page_num['page_num_per_group']------------------------每组显示的页码数 $this->page_num['per_page_num']------------------------------每页显示的记录条数 $this->page_num['first_page_num']----------------------------第一页页码 $this->page_num['pre_page_num']------------------------------上一页页码 $this->page_num['next_page_num']-----------------------------下一页页码 $this->page_num['last_page_num']-----------------------------最后一页码 $this->page_num['pre_group_page_num']------------------------上一组显示的页码 $this->page_num['next_group_page_num']-----------------------下一组显示的页码 $this->page_num['cur_group_page']----------------------------当前组的页码列表,是一个数组 $this->page_num['cur_page']----------------------------------当前页码 $this->page_num['cur_group']---------------------------------当前组 $this->page_num['total_group']-------------------------------总组数 $this->page_num['total_page']--------------------------------总页数 $this->page_num['cur_item_num']------------------------------当前页的记录条数 */ function get_page_num() { return $this->page_num; } function get_cur_page() { return $this->cur_page; } } class pager_str extends pager { //设定 var $total_item_str = " 共%s条 "; //共多少条,如果为空表示不要此项 var $cur_item_str = "当前页%s条 "; //当前页多少条,如果为空表示不要此项 var $tj_cur_page_str = "%s/"; //统计段当前页码,如果为空表示不要此项 var $total_page_str = "%s页 "; //总页数,如果为空表示不要此项 var $first_page_str = "<a class="text_link_class" href="%s">首页</a> "; //第一页,如果为空表示不要此项 var $first_page_str2 = "首页 "; //第一页,没有链接的情况,如果为空表示不要此项 var $pre_page_str = "<a class="text_link_class" href="%s">上页</a> "; //上一页,如果为空表示不要此项 var $pre_page_str2 = "上页 "; //上一页,没有链接的情况,如果为空表示不要此项 var $next_page_str = " <a class="text_link_class" href="%s">下页</a> "; //下一页,如果为空表示不要此项 var $next_page_str2 = " 下页 "; //下一页,没有链接的情况,如果为空表示不要此项 var $last_page_str = "<a class="text_link_class" href="%s">尾页</a> "; //最后一页,如果为空表示不要此项 var $last_page_str2 = "尾页 "; //最后一页,没有链接的情况,如果为空表示不要此项 var $go_text_str = " <input name="page" size="3" type="text" value="%s" /> "; //跳转框,如果为空表示不要跳转 var $go_submit_str = " <input name="go" type="submit" value="GO" /> "; //跳转按钮 var $group_split_str = ' ... '; //分页组的分割符,如果为空表示不用显示页数 var $page_split_str = ' '; //页码之间的分割符 var $cur_page_str = "<span class="cur_page_class">%s</span>"; //当前页页码 var $not_cur_page_str = "<a class="num_link_class" href="%s">%s</a>"; //非当前页页码 var $url_start = ''; //网址头 var $url_end = ''; //网址尾 var $style_table = 'border="0" cellpadding="0" cellspacing="0" style="border:0px;"'; //表格样式 var $style_td = 'align="left" style="border-bottom:0px; border-top:0px;"'; //单元格样式 var $page_str = ''; //将要输出的分页内容 function pager_str($options = array()) { global $mod, $do; foreach ( $options as $k=>$v ) { $this->$k = $v; } /* if ($this->url_start == '') { $this->url_start = '/' . $mod . '/'; } if (substr($this->url_start, -1) != '/') //在最后加上'/' { $this->url_start .= '/'; } if ($this->url_end == '') { $this->url_end = $do . '.html'; } if (substr($this->url_end, 0, 1) == '/') //去掉开头的'/' { $this->url_end = substr($this->url_end, 0, -1); } */ //$this->url_start = '/' . $mod . '/; $this->url_start = '?'; $url_arr = array(); if (isset($_POST) && sizeof($_POST) && isset($_GET) && sizeof($_GET)) { $url_arr = array_merge($_POST, $_GET); } else if (isset($_POST) && sizeof($_POST)) { $url_arr = $_POST; } else if (isset($_GET) && sizeof($_GET)) { $url_arr = $_GET; } if (sizeof($url_arr)) { foreach ($url_arr as $k => $v) { if ($k != 'page' && $k != 'go' && $k != 'mod' && $k != 'do') { if ($k == 'key') { $this->url_start .= trim($k) . '=' . replace_str_for_url($v) . '&'; } else { $this->url_start .= trim($k) . '=' . $v . '&'; } } } } $this->pager($this->total_item, $this->per_page_num, $this->page_num_per_group); if ($this->page_num) { $this->page_str = ' <table border="0">style_table . '>'; $this->page_str .= ($this->go_text_str != '') ? ' <form id="page_go" action="' . $this->url_start . $this->url_end . '" enctype="application/x-www-form-urlencoded" method="post">' : ''; $this->page_str .= ' </form> <tbody> <tr> <td>style_td . '>'; $this->page_str .= ($this->total_item_str != '') ? sprintf($this->total_item_str, $this->total_item) : ''; $this->page_str .= ($this->cur_item_str != '') ? sprintf($this->cur_item_str, $this->cur_item_num) : ''; $this->page_str .= ($this->tj_cur_page_str != '') ? sprintf($this->tj_cur_page_str, $this->cur_page) : ''; $this->page_str .= ($this->total_page_str != '') ? sprintf($this->total_page_str, $this->total_page) : ''; if ($this->cur_page == 1) { $this->page_str .= $this->first_page_str2 . $this->pre_page_str2; } else { $this->page_str .= ($this->first_page_str != '') ? sprintf($this->first_page_str, $this->url_start . 'page=' . $this->first_page_num) : ''; $this->page_str .= ($this->pre_page_str != '') ? sprintf($this->pre_page_str, $this->url_start . 'page=' . $this->pre_page_num) : ''; } if ($this->group_split_str != '') { if ($this->pre_group_page_num) { $this->page_str .= ($this->not_cur_page_str != '') ? sprintf($this->not_cur_page_str, $this->url_start . 'page=' . $this->pre_group_page_num, $this->pre_group_page_num) . $this->group_split_str : ''; } foreach ($this->cur_group_page as $k => $v) { if ($this->cur_page == $v) { $this->page_str .= ($this->cur_page_str != '') ? sprintf($this->cur_page_str, $v) : ''; } else { $this->page_str .= ($this->not_cur_page_str != '') ? sprintf($this->not_cur_page_str, $this->url_start . 'page=' . $v, $v) : ''; } $this->page_str .= $this->page_split_str; } if ($this->next_group_page_num) { $this->page_str .= ($this->not_cur_page_str != '') ? $this->group_split_str . sprintf($this->not_cur_page_str, $this->url_start . 'page=' . $this->next_group_page_num, $this->next_group_page_num) : ''; } } if ($this->cur_page == $this->total_page) { $this->page_str .= $this->next_page_str2 . $this->last_page_str2; } else { $this->page_str .= ($this->next_page_str != '') ? sprintf($this->next_page_str, $this->url_start . 'page=' . $this->next_page_num) : ''; $this->page_str .= ($this->last_page_str != '') ? sprintf($this->last_page_str, $this->url_start . 'page=' . $this->last_page_num) : ''; } if ($this->go_text_str != '') { $this->page_str .= sprintf($this->go_text_str, $this->cur_page) . $this->go_submit_str; } $this->page_str .= '</td> </tr> '; $this->page_str .= ($this->go_text_str != '') ? '</tbody> ' : ''; $this->page_str .= '</table> '; } else { $this->page_str = ''; } } function get_page_str() { return $this->page_str; } }</veidy>