浏览模式: 标准 | 列表分类:PHP Framework
Submitted by gouki on 2009, March 4, 9:24 PM
如果按照ZEND的手册,在使用Zend_Paginator类的时候有两种方法,一种是直接new,一种是用factory
当然,用factory是很方便的。只需要Zend_Paginator::factory( $array )就行了
可是,如果这个array很大怎么办?它没有说。。
即使是new Zend_Paginator( Zend_Db_xxx ?$array )[不记得括号中是哪个abstract了],如果数据量大,他也没办法的呀??
今天白天我试着一下子查询了1W多条,立马死掉。
我看网上的例子,大多是要么直接传结果,要么是传 ZEND_DB的查询对象进去。但结果集都不大的,所以顺利运行 了。我不知道结果集是上万的时候会怎么样,呵呵
最后我是采用了先COUNT出总数,然后用range生成一个大数组传组 Zend_Paginator::factory() ,因为我看他里面的计数是用count的,所以我对factory的数组参数就直接传了这个range出来的数组给它。
结果,成功了,看来,这也就可以了。只是方法有点妖而己。。
记录一下,备忘一下。
Config文件
[paginator]
page.pagemax = 10
page.pagestart = 1
page.itemperpage = 25
在文件里
PHP代码
- <?php
-
- $request = $this->_request ;
- $currentPage = $request->getParam('page');
- $result = $table->fetchAll( ... 条件 );
- $resultCount = $table->getCount( ... 条件 );
- $resultCountArray = range( 1, $resultCount );
-
- $paginator = Zend_Paginator::factory( $resultCountArray );
- $paginator->setCurrentPage( $currentPage )
- ->setItemPerPage( 25 )
- ->setPageRange( 10 );
- $this->view->paginator = $paginator;
部分参数在获取失败的情况下,会直接从Config文件里读取,这里就不详细写了,大致应该是:
PHP代码
- <?php
-
- $config = new Zend_Config_Ini('...path...' , 'paginator' );
-
- $pageMax = $config->page->pagemax ;
-
Tags: zend, framework, paginator
PHP Framework | 评论:0
| 阅读:24105
Submitted by gouki on 2009, February 21, 9:16 PM
这是一篇TdWeb的笔记,在征得他的同意后,我放了上来。他最初是为Lite版本写的,但现在这些单字母函数在标准版里也都同样存在了。因此这些资料在两个版本的ThinkPHP中都同样适用。由于Tdweb偷了点懒,部分代码都是直接复制过来的,所以,我稍做了一下整理(主要是页面样式的稍做更新,同时对于部分语句进行了一些更新,tdweb莫生气)
原文网址:http://bitctw.cn/hl/docs/
原文如下:(我仅针对单字母函数作介绍)
TP所有单独的函数,除了两个用来生成项目的buildAppDir之类的,其余都在框架目录/Common/functions.php这个文件里。
有人不太喜欢TP这种单字母函数,其实这也是TP的一个特色,如果理解了这些函数的作用,不管是背,还是写,都是非常方便的,接下来我们以字母顺序开始。
A函数(基本是Action的简写)
A函数是用来实例化我们的Action类的,例如我们的程序有2个Action分别是IndexAction和TestAction,在 IndexAction中有个myHello方法能够输出hello world,如果我也想在TestAction中也输出同样一段文字怎么办?最原始的方法首先我们导入IndexAction.class.php这个文 件,然后new IndexAction,最后调用myHello方法才行。
代码一般为 :
PHP代码
- <?php
- import("@.Action.Index");
-
- class TestAction extends Action{
- public function index()
- {
- $index=new IndexAction();
- echo $index->myHello();
- }
- }
- ?>
那么,如果我们用A函数,怎么写呢?
PHP代码
- <?php
- class TestAction extends Action{
- public function index()
- {
- $index=A("Index");
- echo $index->myHello();
- }
- }
- ?>
呵呵,少写很多代码吧。当然,这还不是最偷懒的方法,请看下边的R()函数,就知道什么是偷懒的极致了。
B函数
这是随着行为应运而生的新生函数,可以执行某个行为,例如B('app_begin');就是在项目开始之前,执行这个行为定义的所有函 数,支持2个参数,第二个参数支持需要接受一个数组,例如B('app_begin',array("name"=>"tdweb","time"=>time()));这样。
C函数
获取配置值,这个大家用的应该不少。虽然使用方便,但是C函数无疑是一个非常强大的函数。
获取值:
获取所有设置:C(); 不传递任何参数,返回一个包含所有设置的数组。
获取指定配置:C('URL_MODEL') 这样就能得到URL_MODEL的配置信息
获取指定二维数组配置:C("array.name"),这样就返回数组array下的key为name所对应的值
设置值:
为二维数组赋值C("array.name","value"),原理同上(获取array.name的值),后边的value是值
批量赋值:
$test=array("URL_MODEL"=>1,"THIN_MODEL"=>true");
C($test);
这样直接将数组里的值赋值了
判断是否赋值:
C("?URL_MODEL")这样前边加个"?",如果已经赋值,则返回true
需要说明的是,这里虽然更改了配置的值,但是仅仅是这个页面做了更改,到下个页面就不起作用了,如果想改就永久更改,那么需要配合F函数,将配置文件写入config.php才行。
D函数
DAO函数应该是我们写程序用的最多的函数了。和A函数类似,如果不使用D函数,就需要导入Model,然后new Model,剩下都是一样的。
但是D函数有2个有点,一是如果之前实例化过这个Model,那么就不再实例化了,剩资源;二是方便调试,如果不存在 这个Model,会抛出TP异常,非常人性化。
如果访问本项目的Model直接D("Model名称");就可以了,如果打算跨项目访问,就使用 D("Model名称","项目名称");其他的就没什么说的了
F函数
快速读取和保存文件数据
快速保存数据:F("mydata","这里是要保存的数据"),这样就在项目Data目录下保存了一个名叫mydata.php的文件,里边的内容是该函数的第二个参数。
指定保存时间 :F("mydata","这里是要保存的数据","60"),这样,如果下次再访问,间隔大于60秒则删除次缓存文件。
指定保存目录:F("mydata","这里是要保存的数据","60",DATA_PATH) ,这样就指定保存在data目录下
立即删除缓存:F("mydata",null),第二个参数传递一个null值,这样就删除了mydate这个缓存
读取缓存数据:F("mydata"),这样就读取这个缓存了
L函数
语言定义函数,L("intro")获取定义成intro的语言,l("intro","介绍")为intro赋值,关于这个赋值的长久性,道理同C函数一样。
R函数
还记得我们的A函数吧,如果仅仅想执行某个方法,其实用R函数更方便,刚才的可以替换成
PHP代码
- <?php
- class TestAction extends Action{
- public function index()
- {
- $index=R("Index","myHello");
- echo $index;
- }
- }
- ?>
呵呵,是不是更简单?
S函数
全局缓存读写函数,和C类似,不过是直接写成文件的哦,写在Temp目录下,不过在缓存有一点需要注意,如果缓存名称是aaa,那么缓存生成的文件名称就是md5("aaa")的值,值得注意。
U函数
U函数是很强大的一个函数,它主要是进行URL组装,同时支持不同模式和路由
例如:
取得当前模块的Action地址 :U("/nowMethod");
取得当前模块的Action地址,并传递参数:U("/nowMethod?params=test");
(如果不习惯上边那种方式,可以使用U("/nowMethod",array("params"=>"test");这样的数组方式传递参数,效果是一样的)
访问其他模块的方法:U("Other/otherMethod"),这样就是访问Other模块下的otherMethod方法
跨项目访问:U("appname://Other/otherMethod");
使用路由访问:U("appName://routeName@moduleName/actionName?params");
另外,如果想直接跳转,那么就在第二个参数写1,例如U("/nowMethod",1);这样就直接调转到指定URL了
好了,介绍了TP的9大函数,相信你或多或少也有些了解了吧。如果想了解更多更好的功能,请看function.php的代码,注释很详尽
稍微排版了下,也删了点不太和谐的内容,希望可以给大家带来帮助。。
Tags: thinkphp, 单字母, 函数, 整理
PHP Framework | 评论:1
| 阅读:33977
Submitted by gouki on 2009, January 19, 4:05 PM
群友Bopo自己开发了一个PHP的framework。Bopo从认识到现在,大概也有四五年的时间了吧,不过这个框架的年龄并不是特别长,大概只有2年多左右。最早这个框架BOPO是自己做项目的时候一点点的做的,但后来他终于有想法将它逐步扩大成为了一个框架。
最初看到框架的时候,还是一个雏型,现在,比以前好多了,所提供的支持也多了很多。让我们来看看这个糖浆究竟有些什么。
Treacle 是个什么呢?
Treacle 为开发者轻松、快捷的创建应用程序提供帮助。Treacle 框架简单、清晰,容易理解和学习,并且有完全中文化的文档和丰富的示例程序降低学习成本。
Treacle 有什么特点?
- 完全跨平台
- 完全支持 PHP5
- 不倚赖特别的 PHP 扩展模块
- 简单、容易理解的 MVC 模型
- 丰富的助手对象和组件
- 开放源代码,完全中文化的注释和文档
- 商业公司提供技术支持
如何获取技术支持?
您可以通过参与我们的论坛来获得技术支持。
官方网址:http://www.treacle.cn/
可能现在有些简陋,但是期待一下吧。
Tags: framework, treacle, bopo
PHP Framework | 评论:0
| 阅读:20717
Submitted by gouki on 2009, January 19, 2:23 PM
一大早流年就在群里说发布了Lite版本,但是我还没有欣赏一下具体的代码,好象这个版本的想法是用Yhustc那里冒出来的,因为他的Yblog就自行对ThinkPHP 1.5进行了简化只保留了常用的功能,比如:数据库只支持MYSQL(也是,这个博客程序只用MYSQL,其他的一些驱动就可有可无了)。于是流年在这个想法的基础上,花了几天时间进行了Lite的构造。(估计几天的休息时间就这么没有了吧)
官方原文:http://www.thinkphp.cn/Blog/25
发布该版本的原因是很多应用开发要求较高的性能并且不需要很多特殊的功能
Lite版本提供网站开发最需要的功能,优化性能,更适合大型项目!
[ 功能列表 ]
编译缓存
自动生成
异常处理
URL模式
语言包支持
模板主题支持
空模块和空操作
前置和后置操作
智能数据表识别
自动加载
标签库
类库导入
Vendor支持
ADSL方法
跨库操作
字段映射
URL组装
URL伪静态
原生SQL操作
多数据库连接和切换
分布式数据库支持
支持MySql和PDO
惯例配置
项目配置
动态配置
模块配置
静态缓存
动态缓存
模板引擎和扩展支持
日志处理
SQL日志
调试模式
运行时间显示
页面Trace
类库扩展
自动验证
自动完成
CURD基本
AR模式基本
连贯操作
[ 注意事项 ]
去掉了ORG类库包(自己可以增加扩展)
保留文件缓存驱动
保留内置模板引擎和PHP模板引擎驱动
查询条件只支持字符串
CURD接口和数据库接口已经更改(和标准版不兼容)
视图模型和关联操作已经去掉
模型的数据操作保留了 add save delete find query execute 增加了select方法 并做了参数的调整
去掉了自动获取数据表字段信息 改由模型自己定义或者不定义
保留运行信息和页面Trace显示
去掉了URL路由功能(该部分功能可以用空模块和空操作取代)
[ 下载Lite版本 ]
Lite版本适合对TP有一定了解的开发人员,并且有PHP开发经验和足够的扩展能力。
Tags: thinkphp, lite
PHP Framework | 评论:0
| 阅读:23513
Submitted by gouki on 2009, January 8, 9:22 PM
从TP1.5开始,对于其他的模版引擎有了原生支持(不再是以前那种插件机制了)。
本文以使用smarty模版为例作点简单介绍,其他的,可以参考一下View.class.php中的fetch方法可知。
TP的SVN中已经含有smarty模版库,因此当你要使用的时候,只需要在项目的config.php里作一点简单的配置:
PHP代码
- 'TMPL_ENGINE_TYPE' => 'smarty',
从2009-01-07下午的SVN版本里,流年为又增加了一个TMPL_ENGINE_CONFIG这个数组,即:
PHP代码
- 'TMPL_ENGINE_CONFIG' = array(
- 'template_dir' => TMPL_PATH ,
- 'compile_dir' => CACHE_PATH . "tplCompile/",
- 'cache_dir' => CACHE_PATH . "tplCache/",
- 'left_delimiter' => '{',
- 'right_delimiter' => '}',
- 'caching' => false,
- 'force_compile' => true,
- 'compile_check' => true,
- ),
备注:如果按照我这样的写法,请到cache目录里手动创建tplCompile和tplCache两个目录,否则程序会报错。
报错信息大致为:
XML/HTML代码
- Catchable fatal error: Object of class Smarty could not be converted to string in D:\local\htdocs\ThinkPHP\Album\Temp\~runtime.php on line 145
如果出现这样的报错信息,请先检查这两个目录是否存在
在项目开发的时候,caching 最好设为false,否则你根本看不到效果。
如此设定完毕后,你就可以直接在项目中使用了,下面以Index模块的index方法进行举例:在IndexAction.class.php的index的方法里
PHP代码
- $this->assign("test" , "This is a test string");
- $this->display();
然后到模版里:
就可以看到输出了。不过,这里需要注意的是,如果你$this->display()没有指定文件名,那么默认的模版文件就是default/Index/index.html,这点和原先使用TP默认的模版引擎没有什么区别。
出现问题最大的应该是在include方法里,include的使用方法是:{include file="Public/header.html"},就象我前面所说,smarty的模版路径只指到了tpl目录,但实际上,我们是在默认的default目录下操作,因此正确的写法应该是{include file="default/Public/header.html"}
如果我们写的程序要对应多模版,那么,上面那种直接写死default的方法是不行的,还好,TP为我们留了一个常量:TEMPLATE_NAME,于是我们的写法就可以是现在这样:
XML/HTML代码
- {include file="`$smarty.const.TEMPLATE_NAME`/Public/header.html"}
现在试一下,是否公用目录里的header.html被加载了?
最后再报一个warning。如果是在WINDOWS下面开发并且开启了DEBUG_MODE,那么你在读取模版的时候,页面的Trace信息里,偶尔会出现一个注意:
XML/HTML代码
- [ 09-01-08 14:36:02 ] 注意:[2] unlink(./Cache/tplCompile/\%%70^706^706C3AFE%%index.html.php) [function.unlink]: No such file or directory core.write_file.php 第 44 行.
这些信息,可以被忽略掉。模版文件还是会正常的生成和编译的。它只会在第一次生成模版编译文件的时候出现
Tags: thinkphp, smarty, template
PHP Framework | 评论:0
| 阅读:27093