Основы синтаксиса PHP
Используйте <?php
Не используйте <? ?> и прочие способы размещения в файле php-скриптов. Да, может быть, у вас все работает, а вот на другом сервере — не факт. На некоторых серверах короткие тэги вообще отключены. Не рискуйте, используйте только <?php. И кстати, не ставьте закрывающий php-тег — это признак дурного тона. А еще закрывающий тэг в конце может привести к неожиданным проблемам, связанным со случайно поставленным пробелом или переводом строки в конце вывода.
<? … ?> // Неправильно
<?php … // Правильно
<?=$Var?> // Неправильно
<?php echo $Var // Правильно
|
Отделяйте файлы с параметрами
Нет ни одной достаточно веской причины, которая бы оправдала хранение настроек в одном файле со скриптом. Всегда создавайте отдельный файл и в самом начале скрипта его подключайте. Вы поймете, как это важно, когда вам придется редактировать кучу файлов из-за изменения одного параметра. Это ведь совсем несложно:
include(«config.php»);
Комментарии — ваши друзья
Конечно, если вы спешите или набиваете код на волне вдохновения, становится как-то не до комментариев. Но код, написанный давно, понимать трудно — даже если писали его вы. Лучше помогите себе парой комментариев в ключевых местах, чтобы потом сократить время на понимание очередного скрипта.
1
2
3
|
// Однострочный комментарий
/** Многострочный
комментарий **/
|
Правда, просто? Еще стоит обратить внимание на PHPDoc.
Грамотно форматируйте код
Нет ничего хуже огромной стены кода, автор которого явно не знал о существовании кнопки Tab. Не спасут даже комментарии — отступы придумали для того, чтобы логически отделять друг от друга фрагменты кода. А использование или неиспользование отступов много говорит о вас как о программисте. Вот этот код отформатирован неправильно:
1
2
3
4
5
|
function dothisformula($a,$b) { $c = $b+$a;
$e=3;
while ($c < 20) {
$e = $e — 1; $c = $c + 1; }
return $e; }
|
А вот это — тот же самый код, но с правильным форматированием:
1
2
3
4
5
6
7
8
9
10
|
function dothisformula($a, $b)
{
$c = $b + $a;
$e = 3;
while ($c < 20) {
$e = $e — 1;
$c = $c + 1;
}
return $e;
}
|
Если вы хотите точно знать, какой способ форматирования кода правильный — почитайте PSR-ы.
Давайте переменным понятные имена
Конечно, к единому мнению по этому вопросу прийти нельзя. camelCase или under_score? Нужна ли Венгерская нотация? Важно здесь одно: раз и навсегда определитесь, что вам ближе. А даже если вам и захочется изменить стиль, то пожалуйста, не делайте это посреди проекта! Разные варианты именования переменных в одном проекте или, что еще хуже, в одном файле — это ужасно. И никаких магических чисел! Не поленитесь использовать константы.
Инициализируйте переменные
Конечно, PHP автоматически создает переменные при попытке к ним обратиться. Но вам не кажется, что пользоваться этой особенностью довольно рискованно? Хорошей практикой считается всегда инициализировать переменные еще перед первым использованием. Это сделает код понятнее и поможет убедиться, что вы не обращаетесь случайно к неинициализированной переменной.
1
2
3
|
$foo = array();
$bar = 0;
$baz = false;
|
Булева переменная ложна, иначе — истинна
Если вы проверяете какое-то условие и потом результат сравнения сохраняете в булевом значении, при инициализации переменной для результата (мы ведь всегда заранее инициализируем переменную, помните?) сначала присваивайте ей false. То есть вот так делать не надо:
1
2
3
4
5
6
7
8
9
|
function getStatus()
{
$result = true;
if ($i != 2)
$result = false;
return $result;
}
|
Лучше вот так:
1
2
3
4
5
6
7
8
9
|
function getStatus()
{
$result = false;
if ($i == 2)
$result = true;
return $result;
}
|
Зачем это? Представьте, что вы проверяете данные перед запросом к базе. Если по какой-то причине блок if вдруг не выполнится, то значение переменной останетсяfalse — так вы подстрахуете себя от попадания в базу ошибочных данных. В коде порой приходится иметь дело с конфиденциальными данными, так что лучше сначала исходить из того, что все данные ошибочны, пока не доказано обратное. Это правило практически написано кровью.
Кстати, лучше проверять, являются ли данные такими, как надо нам, чем являются ли они такими, как нам не надо.
Используйте кавычки, когда обращаетесь к элементам массива
В коде разных разработчиков можно увидеть два варианта доступа к элементам ассоциативного массива:
1
2
|
$name = $names[‘marc’];
$name = $names[marc];
|
Во время выполнения второго варианта PHP сначала попытается найти константу с именем marc. И только если такой не найдется, marc будет сконвертировано в строку и передано в таком виде. Лучше не думать о том, что может случиться, если вдруг такая константа будет существовать… Всегда ставьте кавычки, чтобы такого не происходило.
Используйте запятые, чтобы обратиться к нескольким строкам в одном вызове
Если вам надо, например, в одном вызове функции обратиться к значению переменной и к строке, лучше используйте запятые, а не точки. Почему? Точка — оператор конкатенации строк, эта операция будет выполняться медленнее. Доказательство.
Еще раз. Так надо:
echo «Hello, my name is «, $name;
А вот так — не надо:
echo «Hello, my name is » . $name;
Пользуйтесь тернарными операторами
Если у вас в коде какое-то очень простое сравнение, желательно использовать тернарный оператор, чтобы не растягивать простой код на несколько строк. Вот так может выглядеть ваш простой if:
1
2
3
4
|
if ($a == 1)
$b = 2;
else
$b = 3;
|
Но можно записать его и так:
1
|
$b = ($a == 1) ? 2 : 3;
|
Обобщенно тернарный оператор работает следующим образом:
1
|
$variable = ($condition) ? true : false;
|
Используйте для сравнения с булевыми значениями строгое сравнение
Если вы проверяете переменную на true или false, используйте ===, а не ==, которое задействуется в остальных сравнениях. Строгое сравнение из трех знаков равенства сравнит еще и типы переменных.
1
2
|
if ($isMember == true) { … } // Неправильно
if ($isMember === true) { … } // Правильно
|
Используйте инкремент и декремент
Если вам нужно просто увеличить или уменьшить на 1 значение переменной, ни к чему писать эту громоздкую конструкцию:
1
2
|
$number = $number + 1;
$number2 = $number2 — 1;
|
Куда лаконичнее такой вариант:
1
2
|
$number++; // Инкремент
$number2—; // Декремент
|
А главная прелесть этих операций — в том, что одновременно с ними можно выполнять еще какое-нибудь действие (например, if или while). В зависимости от того, написано ли — или ++ до или после самого названия переменной, очередность операций изменяется.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
// Инкремент произойдет после сравнения:
$number = 10;
while ($number++ == 10) { … }
// А здесь декремент произойдет перед сравнением:
$number = 10;
if (—$number == 10) { … }
$number = 10;
$total = $number++;
// $total будет равен 10.
$number = 10;
$total = —$number;
// $total будет равен 9.
|
Используйте сокращенные операторы присваивания
Если переменную надо увеличить или уменьшить на число, не равное 1, то и в этом случае код можно сократить. Например, у вас в коде может быть такое:
1
2
3
4
|
$a = $a + $b;
$a = $a * 5;
$a = $a — $d;
$a = $a / 3;
|
А используя сокращенные операторы, этот же код можно будет записать так:
1
2
3
4
|
$a += $b;
$a *= 5;
$a -= $d;
$a /= 3;
|
Со строками, кстати, это тоже работает. Если понадобится присоединить к существующей строке какую-то часть, сделайте это так:
1
2
|
$string = $string . «hello»;
$string .= «hello»;
|
Создайте отдельную функцию для var_dump
Иногда бывает нужно во время активной отладки часто выводить прямо на страницу значение какой-то переменной. Конечно, лучше лишний раз так не делать, но если все-таки нужно, то имеет смысл себе помочь. Функция может выглядеть так:
1
2
3
4
5
6
|
function d($var)
{
echo «<pre>»;
var_dump($var);
echo «</pre>»;
}
|
Тэг pre используется, чтобы сделать значение более читаемым. Кстати, такое странное имя функции дано неслучайно — оно короткое, хоть и неочевидное. Набрать ее название будет быстро. Только потом не забудьте убрать эту функцию, когда будете подчищать код в конце разработки.
Но лучше всего забыть этот совет и научиться пользоваться XDebug.
Пользуйтесь константами
Если у вас есть переменная, значение которой изменять не стоит, имеет смысл использовать вместо нее константу. Константы можно использовать, чтобы хранить в них пути, сообщения об ошибках и так далее. Имя константам стоит давать капсом — так их будет просто отличить, и вы будете уверены, что вызываете то, что нужно.
1
2
|
define («DIRECTORY», «/path/to/site/»);
echo DIRECTORY;
|
Пользуйтесь $_GET и $_POST
$_REQUEST лучше не использовать. Четко разделяйте данные: $_GET — это параметры, переданные из адресной строки, $_POST — это, например, полученные из формы данные. И не вздумайте передавать в скрипт пароли, особенно незашифрованные, GET-запросом!
1
2
|
$action = $_GET[‘actions’];
$name = $_POST[‘name’];
|
Пользователи могут руками заменить значения в адресной строке на любые произвольные и доставить вам немало хлопот.
Используйте объекты, а не функции
PHP — все-таки в том числе и объектно-ориентированный язык. Если вы работаете над большим проектом, сотни строк функционального кода вам точно быстро надоедят. А если вам нужно хранить множество однотипных параметров, то тем более задумайтесь об использовании соответствующего класса.
Вызывайте методы цепочками
Если вы подряд вызываете несколько методов одного объекта, имеет смысл сократить код, не выписывая каждый раз название этого объекта. Если есть вот такой класс:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
class User
{
function setThis($var)
{
….
return $this;
}
function setThis2($var2)
{
….
return $this;
}
}
|
… то обращаться к его методам можно так:
1
2
3
|
$user = new User();
$user->setThis(…)
->setThis2(…);
|