私はWeb開発者であり、PHP/Laravelフレームワークでコードを記述しています。私はコードを作成するためのベストプラクティスに従うことを目指してきました。クラス内に15〜20行のコードと最大200行のコードを書くのは良い方法です。しかし、毎回、関数に最低40〜50行を書くことになります。ここでは、クライアントと割り当てられたユーザーの詳細を取得するために書いたコードスニペットを示します。PHPでコード行を減らすにはどうしたらいいですか?
public function preMessageSend($client, $assigned)
{
$ticket_number = $client->ticket_number;
$title = $client->title;
$department = $client->department;
$priority = $client->priority;
if ($client->first_name !== null || $client->first_name !== '') {
$client_name = $client->first_name." ".$client->last_name;
} else {
$client_name = $client->username;
}
if ($client->email !== '' || $client->email !== null) {
$client_email = $client->email;
} else {
$client->email = 'Not available';
}
if($client->mobile !== null || $client->mobile !== '') {
$client_mobile = $client->code."".$client->mobile;
} else {
$client_mobile = 'Not available';
}
if($assigned != null) {
if ($assigned->first_name !== null || $assigned->first_name !== '') {
$assigned_name = $assigned->first_name." ".$assigned->last_name;
} else {
$assigned_name = $assigned->username;
}
if ($assigned->email !== '' || $assigned->email !== null) {
$assigned_email = $assigned->email;
} else {
$assigned->email = 'Not available';
}
if($assigned->mobile !== null || $assigned->mobile !== '') {
$assigned_mobile = $assigned->code."".$assigned->mobile;
} else {
$assigned_mobile = 'Not available';
}
if ($assigned->address !== null || $assigned->address !== '') {
$assigned_address = $assigned->address;
} else {
$assigned_address = 'Not available';
}
$this->sendMessageWithAssigned($ticket_number, $title, $department, $priority, $client_name, $client_email, $client_mobile, $assigned_name, $assigned_email, $assigned_mobile, $assigned_address);
} else {
$this->sendMessageWithoutAssigned($ticket_number, $title, $department, $priority, $client_name, $client_email, $client_mobile);
}
私は私のクラスや関数でLOCを削減し、このような長い関数を書く回避するためのベストプラクティス何ができる方法を教えてください。 TIA
あなたが行うことができ
最初の質問:なぜこれらのクライアントオブジェクトのプロパティをすべてローカルスコープの変数に割り当てる必要がありますか? –
私はあなたが 'nullではなく空の文字列ではなく、空のチェックをすることができると思います。 – danopz
ほとんどの条件を三項演算子に書き直すことができます。 $ client-> mobile!== '')? $ client-> code: "$ client-> mobile: '利用できません'; ' –