PHP编程一定要改掉的5个不良习惯
发布:smiling 来源: PHP粉丝网 添加日期:2022-03-27 09:57:15 浏览: 评论:0
在项目的每一次提交之后,我都会进行大量代码审查,会经常看到一些重复出现的错误,以下这五个错误应该要及时纠正,这是纠正它们的方法。
这5个PHP编程中的不良习惯,一定要改掉 PHP世界上最好的语言!
测试循环前数组是否为空?
- $items = [];
- // ...
- if (count($items) > 0) {
- foreach ($items as $item) { // process on $item ...
- }}
foreach循环或数组函数(array_*)可以处理空数组。
不需要先进行测试
可以减少一层缩进
- $items = [];
- // ...
- foreach ($items as $item) { // process on $item ...
- }
将方法的所有内容封装在if语句中
- function foo(User $user) {
- if (!$user->isDisafunction foo(User $user) {
- if (!$user->isDisabled()) {
- // ...
- // long process
- // ...
- }
- }bled()) {
- // ...
- // long process
- // ...
- }
- }
这不是特定于PHP的,但我经常看到它。你可以通过提前返回,来减少缩进级别的极简代码! 该函数的所有“有用”主体现在处于第一个缩进级别。
- function foo(User $user) {
- if ($user->isDisabled()) {
- return;
- } // ...
- // long process
- // ...
- }
多次调用isset方法
- $a = null;
- $b = null;
- $c = null;
- // ...
- if (!isset($a) || !isset($b) || !isset($c)) {
- throw new Exception("undefined variable");
- }
- // or
- if (isset($a) && isset($b) && isset($c) {
- // process with $a, $b et $c
- }
- // or
- $items = [];
- //...
- if (isset($items['user']) && isset($items['user']['id']) {
- // process with $items['user']['id']
- }
我们经常需要检查是否已定义变量(而不是null),在PHP中,我们可以使用isset函数来做到这一点,而且该函数一次可以接受多个参数!
- $a = null;
- $b = null;
- $c = null;
- // ...
- if (!isset($a, $b, $c)) {
- throw new Exception("undefined variable");
- }
- // or
- if (isset($a, $b, $c)) {
- // process with $a, $b et $c
- }
- // or
- $items = [];
- //...
- if (isset($items['user'], $items['user']['id'])) {
- // process with $items['user']['id']
- }
echo方法和sprintf结合使用
$name = "John Doe";
echo sprintf('Bonjour %s', $name);
这段代码可能在微笑,但是我碰巧写了一段时间,而且我仍然看到很多!除了结合echo和sprintf,我们可以简单地使用printf方法。
$name = "John Doe";
printf('Bonjour %s', $name);
通过组合两种方法检查数组中键的存在
- $items = [
- 'one_key' => 'John',
- 'search_key' => 'Jane',
- ];if (in_array('search_key', array_keys($items))) {
- // process
- }
最后一个错误我看到的往往是联合使用in_array和array_keys,所有这些都可以使用array_key_exists替换。
- $items = [
- 'one_key' => 'John',
- 'search_key' => 'Jane',
- ];if (array_key_exists('search_key', $items)) {
- // process
- }
我们还可以使用isset来检查值是否是null。
- if (isset($items['search_key'])) {
- // process
- }
Tags: PHP编程不良习惯
- 上一篇:聊聊 PHP 8 新特性 Attributes
- 下一篇:最后一页
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)