ECSHOP 开发总结

今天算是仔细学习ecshop 的第一天,实话说,如果不是任务紧,肯定不用这个东西。2013年之后都不再维护了。使用起来万一出什么BUG 就不好了。而且不是纯粹的MVC ,看代码也是怪怪的呢。但是都已经选择了,用一用吧。
1. ecshop的 MVC 
虽然ecshop 不是纯粹的MVC ,但是人家还是使用 smarty  模板技术的。模板技术的出现就是为了更好的分离后台php代码和前台html 代码。在 ecshop 里面,cls_template.php 是核心文件,是一个精简的 smarty 模板引擎。对应的我们可以看到根目录下面有许多.php 文件:

根据名字就可以很清晰的知道这个 php 文件的作用,实际上就相当于我们其他框架里面的controller 部分了。我们随便打开几个文件看看怎么使用的:
index.php :

user.php:

可以看到,在 user.php 里面没有一个方法,通篇就是各种 if 判断,然后 各种 assign 和各种 display 给前台传递数据。同样的前面的 index.php 里面也是一样的:

通篇一共就这么几个函数,然后就是大段的代码,给前台传递数据(中间可能用些逻辑需要重复使用,就封到几个小函数里面了)。咱不能说这种结构不好,毕竟这是近十年前的项目了嘛。总之这里 controller 向 view 层传递数据的逻辑就是这个样子,没有什么特别的。至于 controller 层怎么跟数据库打交道呢? 我们就不详细谈了,ecshop 没有使用ORM 技术,代码里面各种大段大段的 sql 语句。让我想到万一将来某一天需要在表里添加什么字段是不是要大段大段的找sql 语句改呢?算了,先搞定手头,先不管那么多了。
2. view 层的组织方式
其实对于这种相对成熟的开源项目,改controller 的机会很少的,也就是改哪些.php 的机会很少,大多数时候,所谓的二次开发都是针对前台页面,改改样式罢了。那么这里就需要我们去探究一下究竟ec 的前台是怎么组织的。
首先介绍一下,ec 里面,跟前台view相关的有两种文件,一种是.dwt 文件,一种是.lib 文件:

搞明白前台结构的第一点,就是搞清楚这两种文件的联系。
玩过discuz的同学都知道 discuz 有个 diy 功能, diy 相当于一个独立的块。我们可以自己写.htm 文件,然后在 .htm 里面加入 diy 区块,然后自己通过点点点傻瓜式操作把后台数据读取出来:

像上面这样,这里我要说的是,其实ec 也有这样的功能,自定义的 diy 区块就相当于 .lib 文件,这个区块可以被其他地方使用,举个例子,比如你有好几个页面需要用到历史浏览。你总不能在每个页面都写同样的逻辑吧? 那么我们就可以把历史浏览定义成一个.lib 文件,而且数据也已经准备好了。当我们在写不同页面的时候,我们直接使用:

如上,在 BeginLibraryItem 和  EndLibraryItem   之间的就是一个区块
 
   
  1. <!-- TemplateBeginEditable name="首页公告下广告" -->
  2. <!-- #BeginLibraryItem "/library/ad_position.lbi" -->
  3. .lib文件 里面的东东
  4. <!-- #EndLibraryItem -->
也就是说 .dwt 文件 是搭架子,具体某个地方需要用一些小部件的话,可以直接调用 .lib 文件。其实,.dwt 和 .lib 文件里面的内容很像,毕竟都是前台哪些东西嘛:

如上,其实你也分不清那种文件是.dwt ,那种是.lib 。都一样的。按照功能不同分这么两种东西,然后.dwt 可以调用.lib 区块内容。
下面该说一个重点,重点,重点。重要话说三遍,你要记住.dwt 文件并不是所有地方都是可以编辑的。一般一个地方如果引用了.lib 文件,你再进行编辑是不起作用的。示例如下:
 
   
  1. <div class="mod1con shop_notice">
  2. <!-- TemplateBeginEditable name="商店公告" -->
  3. <!-- #BeginLibraryItem "/library/cat_articles.lbi" -->
  4. <h1 class="mod2tit" style="height:0"><a href="{$articles_cat.url}" class="more" style="margin-top:3px;">更多</a></h1>
  5. <div class="mod2con clearfix">
  6. <ul>
  7. {foreach from=$new_articles item=article_item}
  8. <li style="width:250px; margin-right:20px; display:inline; height:25px; line-height:25px;" class="fl"><a href="{$article_item.url}" title="{$article_item.title|escape:html}" class="txtdot">{$article_item.short_title}</a></li>
  9. {/foreach}
  10. <ul>
  11. </div>
  12. <script type="text/javascript">divheight("catArticles");</script>
  13. <!-- #EndLibraryItem -->
  14. <!-- TemplateEndEditable -->
  15. </div>
看上面代码,在.lib 控制范围内,又写了一些代码,很明显是执行不了的(我为这个问题纠结了半个小时呢)。这是看别人模板的写法,也执行不出来,结果是各种纠结啊。算了,不说了。总之 view 层就是这个情况。看着办就行。

总结:后台查数据库,写sql 语句;后台往前台传数据使用smarty 模板; 前台使用这些数据直接{$value} 就行了,会点框架尝试的应该都明白。 就这么点知识,继续改代码了,写日记又废了半个多小时了。。。


















转载于:https://www.cnblogs.com/nkyhq/p/5264134.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将文件解压到项目文件夹下 修改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、付费专栏及课程。

余额充值