Rumah >pembangunan bahagian belakang >tutorial php >Cara Mentakrifkan Sifat Kelas dengan Nilai Lalai Kompleks dalam PHP
Penyelesaian untuk Sintaks Asas Tidak Dihuraikan
Peraturan sintaks ketat PHP boleh menjadi halangan apabila mentakrifkan sifat kelas dengan nilai lalai yang kompleks. Walaupun sintaks seperti (1 << 0) mungkin kelihatan mudah, PHP menganggapnya sebagai ungkapan dengan kesan sampingan, bukan nilai lalai yang sah dalam pengisytiharan kelas.
Memahami Had Pengisytiharan Kelas PHP
Dalam PHP, nilai lalai untuk pemalar kelas atau sifat mestilah nilai primitif, seperti:
const ABC = 8; static $GHI = 15;
Sekatan ini berpunca daripada prinsip bahawa pernyataan deklaratif tidak boleh mencipta kesan sampingan.
Mencipta Jenis Ditentukan Pengguna dan Memulakan dengan Ungkapan
Untuk mengatasi had ini, kami boleh mencipta jenis yang ditentukan pengguna dan memulakannya dengan ungkapan di luar pengisytiharan kelas:
class SDK { // Example of self-created type static private $STRING_NONE = 1 << 0; } $fString = SDK::$STRING_NONE;
Memfaktorkan Semula Kelas Asal
Menggunakan penyelesaian ini pada contoh kelas asal:
class SDK { static private $_types = null; static public function getType($type_name) { self::_init_types(); return self::$_types[$type_name]; } static private function _init_types() { if (!is_array(self::$_types)) { self::$_types = array( 'STRING_NONE' => 1 << 0, // ... rest of types here ); } } function __construct($fString = null) { if (is_null($fString)) { $fString = self::getType('STRING_NONE') & self::getType('STRING_HOSTS'); } } } $SDK =& new SDK(SDK::getType('STRING_HOSTS'));Pendekatan ini membolehkan kami menentukan dan menggunakan jenis dalam kelas sambil menampung nilai lalai yang merupakan hasil ungkapan.
Atas ialah kandungan terperinci Cara Mentakrifkan Sifat Kelas dengan Nilai Lalai Kompleks dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!