CRMEB开源商城系统 & 标准版系统(PHP)开发规范

一个项目在着手开发之前,一定要确定好相关的开发规范。比如文件目录结构、方法名称、变量名称、代码风格以及注释等。本期内容,我们就以CRMEB开源商城系统 & 标准版系统(PHP)为示例,系统的介绍一下本项目中的开发规范。

一、文件目录

CRMEB标准版系统(PHP)的框架使用的是ThinkPHP6,主要目录和框架目录相似,在这里说明一下项目中使用到的主要目录:

1、程序根目录下的crmeb目录是系统的核心目录,程序的核心功能都在这个文件夹下,基类、支付、短信、授权、导出、云存储等基本功能都在次文件夹下。

注意❗️❗️ 这个文件日常开发中尽量不要修改,如果必须要增加一个基础功能时,再去修改此文件夹。

2、app是ThinkPHP默认的目录,但是项目在app文件夹下进行了功能性的细化,包括model、dao、services等。

model:对应数据库的文件,保证每一张表都有一个model对应,这是一个最简单的model文件,命名空间,引用基类,pk是表主键,name是表名称。

dao层文件:只做数据查询、添加、修改等数据库操作,不做任何数据处理。

services层:处理程序的主要逻辑,如果构造方法注入dao层文件,services层的文件和dao层文件不是一一对应的。

controller层:这个里面的文件用于接收数据和发送数据,接收到数据之后调用对应处理数据的service层代码进行处理,再将返回值发送给请求方。

二、代码的开发

namespace和use规范:

(1)namespace声明后必须插入一个空白行

(2)所有use必须在namespace后声明

(3)每条use声明语句必须只有一个use关键词

(4)use声明语句块后必须要有一个空白行

类的定义:使用英文名词,以大写字母作为词的分隔,其他的字母均使用小写,名词的首个字母使用大写,不使用下划线,extends必须和类名在同一行。

定义的每个属性都必须添加访问修饰符:public、protected或private。

方法的命名规则:使用小驼峰命名

(1)使用英文名词、动词,以大写字母作为词的分隔,其他的字母均使用小写,单词的首个字母使用小写;

(2)不使用下划线参数,严格情况下需要声明变量类型,有默认值的参数需要在最后面;

(3)每一个方法都要有注释,表明方法用途、传入参数和类型、返回的参数类型等。

所有的运算符左右都要留下空格,类似下面的方法:

(1)PHP所有关键字必须全部小写

(2)非空行后一定不能有多余的空格符

(3)每行一定不能存在多于一条语句

(4)适当空行可以使得阅读代码更加方便以及有助于代码的分块(但注意不能滥用空行)。

温馨提示:在功能逻辑实现过程中,避免在循环中进行数据库的操作!

相关推荐
独泪了无痕1 小时前
Lodash-JavaScript的实用工具库
前端·javascript
有趣的老凌1 小时前
用 Vibe Coding 搭了一个完整小程序「一定能成」
前端·javascript·后端
山河木马15 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷16 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷16 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
朦胧之17 小时前
页面白屏卡住排查方法
前端·javascript
犇驫聊AI18 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen18 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
用户298698530141 天前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
labixiong1 天前
手写Promise--微任务、静态方法、async/await 全搞懂(三)
前端·javascript