式を使用したクラス プロパティ定義の解析問題の回避策
PHP の基本構文は通常は簡単ですが、作業中に問題が発生する場合があります。クラスプロパティを使用します。一般的な課題は、プロパティ定義内で等号の右側に式を使用できるようにすることです。ただし、このアプローチでは解析エラーが発生する可能性があります。この制限を克服するには、可読性と将来の拡張性を維持するための回避策が必要です。
この問題は、PHP がクラス定数またはプロパティのデフォルト値としてプリミティブ値のみを許可するために発生します。一方、式にはアクションが含まれるため、このコンテキストでは使用できません。これに対処するには、次のアプローチを検討できます。
クラス定義のリファクタリング:
式を使用してプロパティを直接定義する代わりに、式を導入してクラスをリファクタリングします。静的に保護された配列 $_types。この配列には、シンボリック名とその数値の間のマッピングが保存されます。
<code class="php">class SDK { static protected $_types = null; // Get the numerical value for a symbolic name static public function getType($type_name) { self::_init_types(); if (array_key_exists($type_name, self::$_types)) { return self::$_types[$type_name]; } else { throw new Exception("unknown type $type_name"); } } }</code>
初期化と使用法:
クラスが初期化されるとき、__construct() を使用します。 $_types 配列から数値を取得し、それらを目的のプロパティに割り当てるメソッドです。
<code class="php">function __construct($fString = null) { if (is_null($fString)) { $fString = self::getType('STRING_NONE') & self::getType('STRING_HOSTS'); } var_dump($fString); }</code>
例:
このアプローチを利用するには、次のように作成できます。 SDK クラスのインスタンス:
<code class="php">$SDK = new SDK(SDK::getType('STRING_HOSTS'));</code>
この回避策を使用すると、クラス プロパティ定義の式に関する解析の問題を回避しながら、コードの可読性と拡張性を維持できます。
以上がPHP の式を使用したクラス プロパティ定義の解析問題の回避策は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。