《细说PHP》第四版 样章 第18章 数据库抽象层PDO 11

18.8.3  完美分页类的代码实现

分页类的编写除了需要使用在18.8.2节中提供的可以操作的3个成员方法,还需要更多的成员,但其他的成员方法和成员属性只需要内部使用,并不需要用户在对象外部操作,所以只要声明为private(私有)封装在对象内部即可。编写分页类Page并声明在page.class.php文件中,代码如下所示:

c89a776da01b4da7ba186da35edb36ad.png

498be73c6de7415abb0928f14893e634.png

9dd8b7fd12d84843a510d2d0bb27f191.png

a4bfbe82621d4f80868e794d0231d410.png

e99ebd9e3ee5433fab90cc91b0f9fb24.png

46c05782499441889cd6b26d554a9020.png

5bba8f54efd54456bb496caa35a52020.png

72c26dc686344ef785782abb3b831537.png

 

18.8.4  完美分页类的应用过程

虽然分页类Page编写起来复杂了一点,但使用起来非常简便。分页类Page最简单的使用只需要以下几条代码:

385cbef8b31a4dd7aba67ae57663fc3d.png

 

在上例中,首先导入了page.class.php文件加载分页类Page,然后实例化Page类的对象,并通过构造方法的参数指定记录总数为1000条;再通过分页对象中的limit属性获取LIMIT从句,组合SQL语句从数据表中获取当页显示记录的条数;最后通过分页对象中的fpage()方法获取全部分页结构信息并输出。Page类的简单使用演示如图18-8所示。

07eddb149ba048c7bf6cb9b35845a8b2.png

图18-8  Page类的简单使用演示

 

如果需要对输出的信息进行修改,可以通过set()方法进行设置。下面的代码设置了全部可改的输出信息,当然也可以只改变部分输出信息。

5a1a1bbcfbf747d1a258f35bd061d136.png

 

Page类中set()方法的应用如图18-9所示。

5f37a4b157ae4bd59ef03fe0bdd9c04d.png

图18-9  Page类中set()方法的应用

 

还可以利用fpage()方法中的参数,设置显示部分分页信息,并通过对参数排序,对显示的信息顺序进行调整。代码如下所示:

e79e4c1ab92444c6a573bafdb55fbef0.png

Page类中fpage()方法参数的应用如图18-10所示。

caac598fa3d24df9864aa1f1158b43af.png

图18-10  Page类中fpage()方法参数的应用

 

如果需要设置每页显示记录条数,或在去往其他页面的同时携带一些本页面的参数,以及改变显示的默认页,都可以通过构造方法的其他参数实现。代码如下所示:

40a6facd2da84f6ebf6f00784cf0f116.png

 

Page类的构造方法应用如图18-11所示。

f6fa80552c5f4948a40ed7a62beb4e68.png

图18-11  Page类的构造方法应用

 

在上例中,通过构造方法的第二个参数设置每页显示10条数据,又通过第三个参数设置跳转页面时传递两个参数过去,在第三个参数中也可以使用数组array("cid"=>5,"search"=>"php"),并通过第四个参数设置默认显示最后一页。

 

 

0fcc2a2dba9e4847a26fc3d425a58221.png

d00a62a2a91146f585a9ac6dda678d23.png

96f73eb86769474b89c46a1a99b33d7e.png

854ee64b4ea84977b0bd4d3643ec15a5.png

bd6b180054fc453eac241c364fa04a14.png

e8c9f73b9ada4a518d0bdc5ae6209b24.png

转载于:https://my.oschina.net/u/4125915/blog/3099085

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值