### PHP开发规范
**遵从 ThinkPHP 规范**
首先要遵从 ThinkPHP 3.2开发手册的开发命名规范,如控制器,模型,视图的命名,大小写等
在此基础上补充大家约定好的一些开发规范;
**开发代码规范**
1、函数文件都应该放在 Application\Common\Common\function.php 文件里面,做为全局的可调用的函数;
函数名字采用 C GNU的惯例,命名使用小写字母和下划线的方式,例如:
> get_client_ip
~~~
/**
* 加载配置文件 支持格式转换 仅支持一级配置
* @param string $file 配置文件名
* @return array
*/
function load_config($file) {
$arr = array();
}
~~~
2、需要引用非 ThinkPHP 约定的第三方类库文件或在开发过程中封装的类库文件都放在 Application\Common\Util 目录下面,
* 第三方类库直接创建新的文件夹,调用
* 封装的类库只是单文件可以直接放在目录中
> 类调用方法:
> import("Common.Util.ZhenPin.Zhenpin"); // 加载文件
> $zhenpin = new \Zhenpin(); // 实例化类
> $zhenpin->qryProductDetail(); // 调用方法
3、项目中公共的操作方法的封装,如果是全局的需要的情况,封装放到Application\Common\Controller\BaseController.class.php 文件里面
4、类命名方法
* 类的方法和属性命名规范使用驼峰命名,区别于函数命名,例如:
> getUserName
> _parseType
通常下划线开头的方法属于私有方法;
* 类中方法的参数命名,第一个字符使用小写字母,在首字符后的所有字都按照类命名规则首字符大写;
~~~
class Goods {
private $imgName; // 图片名 @var array
// 获取图片信息
public function getImageInfo($imgUrl) {
$this->imgName = $imgUrl['name'];
}
}
~~~
5、变量的命名
所有字母都使用小写,使用'_'作为每个词的分界,例如:
> $user_name
6、控制器传值模版的方法名,参考变量的命名方式,区别于操作方法名称
> $this->assign('user_list', $result)
7、常量所有字母都必须大写,单词间用下划线分隔
> APP_PATH
8、代码区间空格
在 "()"括号内不能出现空格,括号外一定有空格,参数之间一定有空格,"="、"." 、";"、"=>"、"as"等符号左右一定有有空格
~~~
if ($var) {
// if
} elseif ($body) {
// else
} else {
// end;
}
~~~
9、所有的名称中,都不能出现数字的方式的命名和拼音的命名,例如,变量
> $var1,$va2,
> $dingdan
10、代码必须保持使用4个空格为标准的缩进,在进行数据库查询的时候调用的方法使用比较多,要进行换行,并且缩进,例如:
~~~
$result = M("User")
->field('user.name as uname, user.title as utitle')
->where('type=1 AND status=1')
->order('id desc')
->select();
~~~
11、Ajax 返回信息写法,统一的写法
三个参数:
success 是否成功状态
code 返回代码
msg 返回提示信息
~~~
if ($data) {
$result = array("success"=>true, 'code'=>200, 'msg'=>'保存成功!');
} else {
$result = array("success"=>false, 'code'=>401, 'msg'=>'保存失败!');
}
$this->ajaxReturn($result);
~~~
* * * * *
**开发代码注释**
友好的开发更需要有规范化的注释,因此,约定好几种开发场景中必须要有相关的注释加以说明
1、在每一次数据库操作的代码前面都要加上相关的说明注释进行描述说明
~~~
// 查询用户列表
$res = M('User')->select();
~~~
2、在封装的函数和方法的前面都要有详细的注释进行描述说明,包含,说明信息,参数信息,返回信息,创建人,时间,如果是更新写上更新说明
~~~
/**
* 编译文件
* @param string $filename 文件名
* @return array
* @creator jig 2017-3-1
*/
~~~
3、在类文件的头部都要有描述说明,包括说明信息,版本号,创建人,日期等 ,在方法前面注明怎么使用说明,参数调用说明,返回说明
~~~
/**
*
* API Goods
* 电商平台商品
* Jig 2016-12-9
*
*/
class Goods {
private $imgName; // 图片名 @var array
// 获取图片信息 @param $imgUrl 图片名称
public function getImageInfo($imgUrl) {
$this->imgName = $imgUrl['name'];
}
}
~~~
**注:**封装的公共的类方法的一定要有更加相信的使用说明
4、在非本文件内的外部函数和类库方法调用使用都要加上注释以说明调用情况
~~~
$result = object_to_array($obj_data); // 调用封装函数将对象转为数组
~~~
* * * * *
**约定一些工作习惯**
1、PHP代码文件必须以 不带BOM的 UTF-8 编码,声明文件编码
2、项目的 Framework 目录下面的文件不要随意改动,如果出现需要增加文件或者修改的情况,请与团队成员做请示沟通,约定好后再做修改
3、每天早上上班第一件事情都应该是更新代码,养成及时更新代码的习惯
4、每天下班前必须将当天的代码提交到 SVN, 并且养成写好注释的习惯
5、我们的开发遵循开发结构,相关的代码应该写在相应的不同架构地方,例如,html 模版文件中,不要写任何的 Javascript 代码,在 Public 有合理的目录结构和文件写 Javascript 代码
* * * * *
**开发中常用的方法命名**
1、index 默认列表页面
2、search 搜索结构页
3、export 导出
4、import 导入
5、view 详情页
6、add 新增
7、save 保存新增
8、edit 编辑
9、update 更新编辑
#### 大家有异议和更好的建议,提交到我这里,该页面也会陆续更新...
一个非常有意思的PHP代码习惯统计
https://segmentfault.com/a/1190000000443795
- 模版
- 前言
- 项目架构
- 项目规范
- HTML
- CSS
- Javascript
- PHP
- MySQL
- 注意规范
- 开发版本管理
- 开发流程
- 系统配置
- 阿里云服务器配置
- 计划任务配置说明
- 开发示例
- Page分页
- Search_param搜索结果赋值
- Add新增
- Edit编辑
- Ajax表单验证
- Ajax二级联动
- Excel 导出数据首位不去0的方法
- POS总部控制
- 下载CSV格式的模板
- 订单唯一码表和订单SKU表实收金额生成
- 快捷日期选择
- JS函数
- ajax_send
- ajax_result
- createQrCodes
- createBarCodes
- printTpl
- JS插件
- BootstrapValidator表单验证插件
- Address省市区插件
- Bootstrap-datepicker日期插件
- Bootstrap-select多选框插件
- Toastr消息提示插件
- PalyAudit扫描声音提示插件
- WebUploader多图片上传插件
- Ueditor富文本编辑器插件
- Function
- alert
- object_to_array
- array_to_object
- get_address
- set_param_url
- get_shops_name
- get_user_name
- get_warehouse
- get_cheapest_sku
- print_attr(新)
- print_img(新)
- get_spu_no(新)
- get_type_name(新)
- get_brand_en(新)
- get_cat_name(新)
- get_attr_name(新)
- spu_cat_info(新)
- get_time_event_price
- get_vendors
- check_total_reduce
- check_total_discount
- get_inventory
- get_delivery
- get_sale_inventory
- get_customer_name
- phone_protection
- get_order_no
- get_event_name
- get_order_status
- get_item_status
- get_ditch_name
- get_card_no
- get_shop_sales
- get_pay_name
- get_season
- amt_format
- get_cat_parent
- print_attr_id
- round_bcadd
- round_bcsub
- round_bcmul
- round_bcdiv
- get_account_name
- Controller
- Common_BaseController
- check_membership_card
- get_menu_list
- importErrorMassage
- Wpos_IndexController
- get_customer_vip_card
- get_shops_id
- calculate_active_integral
- check_numbers_active
- check_goods_active
- Woms_IndexController
- Model
- View
- category
- cycle_date.html
- shop_select门店多选搜索框
- 品牌A-Z排序多选brand_mc.html
- 供应商代码A-Z排序vendor_no_mc.html
- Lib
- BuyerLib
- WarehouseLib
- EventLib
- getTimeEventPrice
- getVipType
- getEvent
- orderTotalEvent
- orderTimeEvent
- getTotalReduce
- getTotalDiscount
- SaleLib
- CustomerLib
- addCustomerService
- GiftcardLib
- WechatLib
- wxRefund
- OrdersLib
- orderLog
- calculatePayinAmount
- calculateSubtotal
- correctPayinAmount
- saveOrderAddress
- getOrderAddress
- setDeliveryNo
- SyncLib
- updateOuterStock
- UserLib
- createCommission
- FlowLib
- orderList
- addOrder
- addLog
- orderInfo
- checkSku
- orderSave
- orderStop
- orderExecute
- skuEdit
- orderPrinta
- scanGoods
- boxClose
- orderOut
- take
- bview
- check
- deliveryStatus
- checkGoods
- GoodsLib
- createGoodsNo
- createNewGoodsNo
- getSystemStyleNo
- getDim
- MallLib
- smsLog
- GoodsBaseLib
- getBrandInfo
- getBrandsInfo
- getAttrIdArray
- getPrintAttr
- getMustAttr
- getCatIdInfo
- valTypeId
- valsTypeId
- getCatNoInfo
- getCatInfo
- getAttrArr
- getAttrInfo
- getValInfo
- getAttrId
- getValId
- getAttrSeaon
- getValueId
- PointsLog
- pointsIn
- pointsUp
- EcGoodsLib
- getSkuInventory
- Tools
- CsvTools
- csvImport
- csvExport
- ExcelTools
- importExcel
- exportExcel
- exportHeadExcel
- MailTools
- SmsTools
- sendMessage
- UploadTools
- ExportTools
- exportData
- TaobaoTools
- getOnsaleItems
- getSkusItems
- PicturesTools
- uploadPicture
- Plugins
- WxBase
- Taobao
- 问题反馈