如何让PHP编码更加好看利于阅读


Posted in PHP onMay 12, 2019

写出优秀的程序代码是一门艺术,要想如此,就必须在一开始就养成良好的编程习惯。良好的编程习惯不仅有助于项目初期的设计(如模块化),还可以使你编写的代码更易于理解,从而使代码的维护工作更轻松、更省力。不好的编程习惯则会造成代码bug,并且会使以后的维护工作困难重重。

本文以PHP语言为例,介绍一些良好的编程习惯,希望能够对你有所帮助。

1. 规划代码结构

优秀的PHP代码应该有清晰的结构。PHP面向对象的特性允许程序员将应用程序分解为函数或方法。如果代码晦涩难懂,你也可以添加注释,使代码的功能一目了然。编码时应尽量将前端代码(HTML/CSS/JavaScript)与应用程序的服务端规则分开,或者你可以使用遵循MVC模式的PHP框架来构建你的应用程序。

2. 编码风格统一

优秀的PHP代码应该具备统一的风格。比如,为变量和函数制定统一的命名规则,为循环任务(比如数据库存取、错误处理)制定统一的接入标准,或者保持有规律的代码缩进,这些编码习惯都可以让别人阅读代码更加轻松。

3. 可移植性

优秀的PHP代码应该具有可移植性。程序员应学会运用PHP现有的特性(比如魔术引号和短标签等),应该了解产品需求,适应PHP的特点,保证写出的PHP代码具有可移植性和跨平台性。

4. 代码安全性

优秀的PHP代码应该具有安全性。PHP5具有卓越的特性和灵活性,但应用程序的安全往往掌握在程序员的手中。作为专业的PHP开发人员,应该对安全漏洞有一些深入了解,常见的安全漏洞有跨站脚本攻击(XSS)、跨站请求伪造(CSRF)、代码注入漏洞和字符编码漏洞等。使用PHP中的特定功能和函数(比如mysql_real_escape_string等)可以帮助程序员写出安全的代码。

5. 添加注释

代码注释是代码中的重要组成部分,它解释了函数运行的目的,这种注释会在代码以后的维护中提供非常有用的帮助。

6. 避免简写标记

应使用完整的起始标记,不推荐使用简写的起始标记。

7. 用单引号代替双引号

由于PHP会对双引号中的内容进行变量搜索,为了避免这种搜索带来的性能影响,程序员应该使用单引号引用字符串。

8. 转义输出

应该在htmlspecialchars函数中使用ENT_QUOTES参数,保证单引号(')也可以被转义。尽管没有规定必须这样做,但这是一个好习惯。

9. 使用逗号隔开字符串输出

字符串连接符(.)可以将单一的字符串传递给echo语句进行输出,与之相比,逗号可以实现echo语句中字符串的分别输出,这对PHP来说是一个性能改善。

10. 在输出前检查传递值

应该记得在输出前检查$_GET['query'] 的传递值。使用isset函数或是empty函数可以检查变量值是否为空。

PHP 相关文章推荐
回答PHPCHINA上的几个问题:URL映射
Feb 14 PHP
php 中的str_replace 函数总结
Apr 27 PHP
php学习之数据类型之间的转换代码
May 29 PHP
php实现无限级分类
Dec 24 PHP
PHP配置把错误日志以邮件方式发送方法(Windows系统)
Jun 23 PHP
yii2控制器Controller Ajax操作示例
Jul 23 PHP
TP(thinkPHP)框架多层控制器和多级控制器的使用示例
Jun 13 PHP
php xhprof使用实例详解
Apr 15 PHP
Centos7安装swoole扩展操作示例
Mar 26 PHP
PHP Trait功能与用法实例分析
Jun 03 PHP
实例化php类时传参的方法分析
Jun 05 PHP
PHP实现简易用户登录系统
Jul 10 PHP
Yii2处理密码加密及验证的方法
May 12 #PHP
php和asp语法上的区别总结
May 12 #PHP
Laravel推荐使用的十个辅助函数
May 10 #PHP
PHP下载大文件失败并限制下载速度的实例代码
May 10 #PHP
PHP 7.4 新语法之箭头函数实例详解
May 09 #PHP
PHP文件类型检查及fileinfo模块安装使用详解
May 09 #PHP
php使用mysqli和pdo扩展,测试对比mysql数据库的执行效率完整示例
May 09 #PHP
You might like
相对路径转化成绝对路径
2007/04/10 PHP
php 智能404跳转代码,适合换域名没改变目录的网站
2010/06/04 PHP
php上传图片客户端和服务器端实现方法
2015/03/30 PHP
PHP在线调试执行的实现方法(附demo源码)
2016/04/28 PHP
Linux系统中为php添加pcntl扩展
2016/08/28 PHP
PHP APP微信提现接口代码
2018/09/30 PHP
微信企业转账之入口类分装php代码
2018/10/01 PHP
PHP实现的62进制转10进制,10进制转62进制函数示例
2019/06/06 PHP
让你的PHP,APACHE,NGINX支持大文件上传
2021/03/09 PHP
js函数名与form表单元素同名冲突的问题
2014/03/07 Javascript
JS+CSS实现鼠标滑过时动态翻滚的导航条效果
2015/09/24 Javascript
jquery实现简单文字提示效果
2015/12/02 Javascript
JS常用字符串方法(推荐)
2021/01/15 Javascript
原生js验证简洁注册登录页面
2016/12/17 Javascript
underscore之Chaining_动力节点Java学院整理
2017/07/10 Javascript
three.js加载obj模型的实例代码
2017/11/10 Javascript
jquery学习笔记之无new构建详解
2017/12/07 jQuery
解决vue中修改export default中脚本报一大堆错的问题
2018/08/27 Javascript
Bootstrap的aria-label和aria-labelledby属性实例详解
2018/11/02 Javascript
JavaScript实现的拼图算法分析
2019/02/13 Javascript
Vue中的组件及路由使用实例代码详解
2019/05/22 Javascript
js+canvas实现五子棋小游戏
2020/08/02 Javascript
tensorflow 获取模型所有参数总和数量的方法
2018/06/14 Python
Django中Middleware中的函数详解
2019/07/18 Python
python或C++读取指定文件夹下的所有图片
2019/08/31 Python
浅谈Pycharm的项目文件名是红色的原因及解决方式
2020/06/01 Python
纯CSS3实现3D旋转书本效果
2016/03/21 HTML / CSS
input元素的url类型和email类型简介
2012/07/11 HTML / CSS
HTML5是什么 HTML5是什么意思 HTML5简介
2012/10/26 HTML / CSS
HTML中meta标签及Keywords
2020/04/15 HTML / CSS
在线学习西班牙语、法语或其他语言:Babbel.com
2018/02/07 全球购物
土木工程应届生求职信
2013/10/31 职场文书
应届实习生的自我评价范文
2014/01/05 职场文书
商业活动邀请函
2014/02/04 职场文书
springboot拦截器无法注入redisTemplate的解决方法
2021/06/27 Java/Android
Nginx使用ngx_http_upstream_module实现负载均衡功能示例
2022/08/05 Servers