TPshop学习
笔记大纲:
- tpshop目录结构
- 功能模块
- 函数库
- 重要配置
- 助手函数
- 插件
- 模板
1、TPshop目录结构
%20-%20%E7%AE%80%E4%B9%A6_files/5742280-ec8bb0df4d0bfc53.png)

看这个图,目录结构一目了然。
下面要讲的内容也是根据这个图展开的。
2、功能模块
%20-%20%E7%AE%80%E4%B9%A6_files/5742280-8b7400f361684bc4.png)

前几天刚刚学习了thinkphp,如果熟悉这个php框架的同学应该知道,application目录下的子目录代表模块。
在这里,有四个模块:
admin代表后台管理模块,
home代表pc web的访问模块,
mobile代表手机端的访问模块,
common代表通用模块,目前只有工具类File,它可供其他模块调用,但是它不能调用业务模块。
home和mobile模块都有各自的base类,base类完成了一些公共的业务功能和提供公共的业务接口,各模块所有控制器都继承于这个类,就不用每个控制器都要实现一遍共同的业务逻辑,比如session的确认等。
还有一个值得学习的是因为有了pc和mobile两个不同的显示设备导致需要制作不同的视图,但是它们内部的业务逻辑是一样的,如果都在各个模块下敲一遍业务逻辑,维护非常麻烦,代码也冗余,所以TPshop在application\home\logic下写了共用逻辑层代码,home和mobile都调用这个公用逻辑部分。
3、函数库
如下两个文件是TPshop内部的函数库,它们对应的定义如下:
application\common.php 共用函数库,依赖于thinkphp框架或TPshop内部配置等;
%20-%20%E7%AE%80%E4%B9%A6_files/5742280-5bb6a9d382d2251e.png)
application\function.php php 基础共用函数库,不依赖其他库,有独立的实现,无关业务,即你可以将这个文件直接用于其他的非thinkphp框架的项目。
我这里列举几个函数
%20-%20%E7%AE%80%E4%B9%A6_files/5742280-9339be5cab42393c.png)
4、重要配置
application\config.php tp官方的配置文件,TPshop在这个文件底部添加了一些自己的配置,如分页配置、订单用户端显示状态、短信使用场景、订单用户端显示按钮 、静态页面等;
application\database.php 数据库配置文件,tp官方的配置文件,注意表前缀。
5、助手函数
www\thinkphp\helper.php TP5 助手函数实现
M( ) D( ) U( ) S( ) C( ) I( ) F( )
网上有许多人吐槽这种难读的代码,我觉得TP3的出发点事这类函数用得太多,比较典型,团队内熟悉一下也比较上手,TP5应该是不建议这样用了,但是为了兼容TP3和部分人习惯,还是以助手形式保留了这类接口。
这个用不用的话,这取决于团队leader的决定了吧。
6、插件
TPshop有插件这样的概念,用官方的话说,就是像手机一样可以安装和卸载app,第三方开发了也可以使用,看来是个不错的设计理念,野心也很大。
%20-%20%E7%AE%80%E4%B9%A6_files/5742280-0ddac947c8513a48.png)
这里主要插件类型是第三方登录支持和第三方支付方式。
你只需拿现有的例子依样画葫芦就可以定制出插件,官方视频里头以支付宝为例子讲了实现原理,建议看一下。
7、模板
ThinkPHP官方的视图文件是一般是放在各个模块之下,但是出于模板可定制和替换的需求,按照原先放在各个模块之下,管理起来非常麻烦容易出错,TPshop将视图目录迁移到根目录的template,当然,这是可改变的。
虽然更换模板操作是在web界面下点击几下按钮实现的,但是其原理非常简单,就是在模块目录下的html.php中更改模板路径即可,如:
'view_path' => './template/pc/default/',
参考:
ThinkPhP5 项目实战(第四讲):TPshop目录结构
http://www.kancloud.cn/tpshop/thinkphp5/280417
TPshop学习的更多相关文章
- TPshop学习(8)微信支付
http://blog.csdn.net/phper8/article/details/76383415 学习内容: https://www.kancloud.cn/tpshop/thinkphp5/ ...
- TPshop用户模块的数据库表关系
看到后台数据库一大坨表项,不熟悉的还真难以下手(如下). 下面讲讲用户模块(User)的数据库表之间的简单关系. 如果安装TPshop官方的学习工程,可以在下面链接进入用户界面: 手机版:http:/ ...
- TPshop入门大纲
笔记大纲: tpshop目录结构 功能模块 函数库 重要配置 助手函数 插件 模板 1.TPshop目录结构 看这个图,目录结构一目了然. 下面要讲的内容也是根据这个图展开的. 2.功能模块 前几天刚 ...
- 2020软件测试自学全套教程-基于python自动化软件测试-2020新版软件测试中级程序员学习路线
不知不觉间,在软件测试行业野蛮的折腾了七年之久.七年之痒也即将过去,但我还是热爱着软件测试这一份工作,一路坚持,走到现在.经历过各种难题,有过迷茫,有过焦虑失眠.也踩过无数的坑,深知行业的不易.自从9 ...
- UI自动化学习笔记- UnitTest单元测试框架详解
一.UnitTest基本使用 1. UnitTest框架 1.1 什么是框架 说明: 框架英文单词frame 为解决一类事情的功能集合 1.2什么是UnitTest框架 概念:UnitTest是pyt ...
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- Angular2学习笔记(1)
Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- 消息队列——RabbitMQ学习笔记
消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...
随机推荐
- [Python] 拉格朗日插值
#-*— coding:utf-8 -*- #Program 0.3 Lagrange Interpolation import matplotlib.pyplot as plt import num ...
- python输入输出及变量
知识内容: 1.python输出及注释 2.变量及常量 3.python用户输入 4.Hello,World程序 一.python输出及注释 1.python输出 在python2和python3中的 ...
- C语言键盘按键无阻塞侦测:kbhit()
http://www.360doc.com/content/12/0414/09/1317564_203474440.shtml kbhit in c kbhit in c: kbhit functi ...
- pythone--002
元组就是不可修改: 字典的索引不是自增的. 元组和列表是: 默认 是key 通过get 没有这个key 是none get可以有默认值: 通过索引 没有就报错. 检查字典中某个可以是否存在:ha ...
- 15. Studio上字符串转整形、整形转字符串例子
var v1=ABS_SQLVALUE("select 1 from dual");var v2=ABS_SQLVALUE("select 2 from dual&quo ...
- 如何给echarts图表添加下载图表成图片的功能
先打开一个现成的图表效果图,注意图中圈出的地方,如图 打开源码找到option,如图 在option下添加toolbox,如图 在toolbox下添加feature,如图 在featu ...
- as3 连接mysql
http://www.cnblogs.com/yili16438/archive/2011/04/23/2025936.html
- Electron mouse events 参数解析
1.https://electronjs.org/docs/api/web-contents 2.通常用: monitorEvents(document.body, 'mouse') 检测正常的值: ...
- SpringCloud——Eureka服务注册和发现
一.SpringCloud和Dubbo SpringCloud整合了一套较为完整的微服务解决方案框架,而Dubbo只是解决了微服务的几个方面的问题. content Dubbo SpringCloud ...
- chrome input去除黄色背景色
input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px white inset; border: 1px solid #CCC!impo ...