EcShop之路-Smarty

来源:http://www.cnblogs.com/dequan-lee/archive/2009/08/06/1540621.html

目前市面上有很多针对PHPMVC模板,但Smarty无疑是在功能和速度上处于绝对领先地位的。MVC(Model-View-Controller)模型-视图-控制器,相信大家对这个概念不陌生,老李也就不详细解释了。EcShop肯定是要采用MVC架构的,不说大家也明白,网店市场的需求是千变万化的,客户对页面的外观组织形式和页面逻辑的要求可谓是“一千个人心中有一千个哈姆雷特”。为了应对这种变化,EcShop必须采用MVC架构。这里顺便提一下,老李不是所谓的模式派或架构派,不会满嘴冒“观察者模式”、“职责链模式”、“依赖倒置”、“接口隔离”、“MVC”、“MVP”等。老李始终觉得根据项目的需要和变化点来设计软件。如果有需要,即便设计出紧耦合的软件也是很Prefect

         好了,继续说Smarty。先说说Smarty的特点:

  1. 速度:相对于其它PHP模板而言,采用Smarty模板编写的程序可以获得最快的速度。注意,是相对于其它PHP模板而言。
  2. 内建缓存支持(大量缓存处理可能不是很完美)
  3. 可以自定义插件。
  4. 可以自行设置模板定界符,如{}{{}}等。
  5. 模板中可以使用控制语句(后面会详细说)
  6. 仅对修改过的模板文件进行重新编译。

         PHP没有内置的Smarty模板类,需要单独下载和配置,大家可以去http://smarty.php.net 上看看。下载后找到libs文件夹,并把它整体复制到将要使用Smarty的应用程序的根目录下(记得改名字哦)libs文件夹包含四个核心文件smarty.class.phpsmarty_Compiler.phpconfig_File.class.phpdebug.tpl,大家有兴趣可以打开看看。不过令老李很奇怪的是,在EcShop中根本发现不到任何Smarty文件的踪迹?原来,EcShop开发团队把Smarty改动一番然后重命名为cls_template.php文件了,呵呵,向EcShop致敬!当然了EcShop肯定是自定义一部分用法和规则,但下面还是抛开EcShop说说通用规则。

         先说Smarty变量,变量来自三个部分:

  1. 来自PHP页面中的变量,即assign()方法传过来的。在EcShop中经常可以看见这种使用。
  2. 保留变量,相当于PHP中的预定义变量(见EcShop之路PHP篇)。在Smarty模板中使用保留变量时,无需使用assign方法传值,直接调用变量名即可。getpostserversession等同于$_GET$_POST$_SERVER$_SESSION
  3. 修饰变量,有的时候不仅仅需要取得变量的值,还需要对变量进行处理,如转化成大写。

         Smarty也有很多内置函数,下面列举几个EcShop中常用的函数:

  1. includeinsert:用来载入其它模板。但insert载入的内容不会被缓存,每次开启页面都会重新执行。
  2. Config_load:用来加载配置文件。
  3. foreach:略,注意用法。
  4. section:用于比较复杂数组的循环访问。
  5. fetch:返回模板的输出内容,但不直接显示出来。

          Smarty就先说到这吧,相信大家多看看代码也就明白了!

将文件解压到项目文件夹下 修改initconfig.php文件 Php数据操作 在需要的文件前加入 use mobile\helper\DbHelper; require_once dirname(__FILE__) . '/helper/DbHelper.php'; 1.DbHelper::select(表名,字段,条件)查询信息 使用: 2.DbHelper::selectRow(表名,字段,条件)查询一行信息 3.DbHelper::selectOne(表名,字段,条件)查询第一行第一个字段信息 4.DbHelper::selectSql(表名,字段,条件)返回查询的sql语句 5.DbHelper::update(表名,需更新字段信息,条件) 6.DbHelper::delect(表名,条件) 删除表信息 7.DbHelper::insert(表名,需插入的字段信息) 添加表信息 上面的表名为去除lola_如lola_users表名即为“user” 参数没有限制,喜欢写sql可以都当字符串传递 表名:“user” 或者 array(“left_join”=>array()) 典型例子(复杂写法有联表查询): echo DbHelper::selectSql( array( "left_join"=>array( "a"=>"museum_decorate_order", "b"=>"users","c"=>"cesi3biao", "on"=>array(//可以将on对应写出字符串 "a.sjsid"=>"b.user_id",//也可以写键值对形式 "a.dd=c.dd" //这样直接写字符 ) //连接条件 )), "a.*,b.user_name as sjsname",//查询字段也可以写成集合形式 array( "a.user_id"=>$_SESSION['user_id'], "a.is_temp = 0", "add"=>"ORDER BY a.id DESC" //为条件最后添加信息 )//筛选条件信息 ); 简单写法 echo DbHelper::selectSql(“users”,”*”,”user_id=12”); insert,update,delect写法大同小异 DbHelper:insert(“users”,array(字段1=>字段值1,字段2=>字段值2......)); DbHelper:update(“users”,array(字段1=>字段值1,字段2=>字段值2......),”user_id=12”); DbHelper::delect(“users”,array(“user_id”=>12)); or DbHelper::delect(“users”,“user_id=12”);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值