廢棄
一些函數已經被廢棄或移除,請不要使用它們
# __autoload - 7.2 版本廢棄
call_user_method_array - 7.0 版本移除
call_user_method - 7.0 版本移除
判斷
# #類別的存在性檢查
相關函數class_exists - 判斷類別是否存在interface_exists - 判斷介面是否存在trait_exists - 判斷Trait 是否存在第二個參數用來決定如果尚未加載,是否使用自動加載。
class_exists ( string $class_name [, bool $autoload = true ] ) : bool interface_exists ( string $interface_name [, bool $autoload = true ] ) : bool trait_exists ( string $traitname [, bool $autoload = true ] ) : bool範例- 廣泛的類別存在性檢查函數
function common_class_exists(string $class): bool { return class_exists($class, false) || interface_exists($class, false) || trait_exists($class, false); }
#類別成員的存在性檢查
相關函數:
property_exists - 檢查屬性是否存在method_exists — 檢查方法是否存在
method_exists ( mixed $object , string $method_name ) : bool property_exists ( mixed $class , string $property ) : bool範例- 實作一個回呼函數,使用者可透過方法或屬性定義回呼的URL
trait RedirectsUsers { public function redirectPath() { if (method_exists($this, 'redirectTo')) { return $this->redirectTo(); } return property_exists($this, 'redirectTo') ? $this->redirectTo : '/home'; } }
類別關係判斷
相關函數:is_a — 物件屬於該類別或該類別的父類,傳回TRUEis_subclass_of — 物件是該類別的子類,傳回TRUEis_a ( object $object , string $class_name [, bool $allow_string = FALSE ] ) : bool is_subclass_of ( object $object , string $class_name ) : bool範例
interface A {} interface B {} class BaseFoo implements B {} class Foo extends BaseFoo implements A{} $foo = new Foo(); // 对象 is_a($foo, 'BaseFoo'); // true is_a($foo, 'Foo'); // true is_a($foo, 'A'); // true // 类 is_a('Foo', 'BaseFoo'); // false is_a('Foo', 'BaseFoo', true); // true, 传入第三个参数,代表允许使用类名而不是示例 is_subclass_of($foo, 'Foo'); // false is_subclass_of($foo, 'BaseFoo'); // true is_subclass_of($foo, 'B'); // true實際情況中,更多的是使用運算符instanceof
$foo instanceof Foo; // true $foo instanceof A; // true $foo instanceof B; // true##操作
相關函數:###
class_alias() - 为一个类创建别名 class_alias ( string $original , string $alias [, bool $autoload = TRUE ] ) : bool###範例- 類別名稱載入器,用於管理類別的別名###
class AliasLoader { private $aliases; public function __construct(array $aliases) { $this->aliases = $aliases; } public function load($alias) { if (isset($this->aliases[$alias])) { return class_alias($this->aliases[$alias], $alias); } } } class LongLongLongLongFoo {} $aliases = [ 'Foo' => 'LongLongLongLongFoo', 'Bar' => 'LongLongLongLongBar', ]; $loader = new AliasLoader($aliases); $loader->load('Foo'); $foo = new Foo(); var_dump($foo); // object(LongLongLongLongFoo)#3395######取得############取得全部#########相關函數:######get_declared_traits — 傳回所有已定義的traits 的陣列######get_declared_interfaces — 傳回一個陣列包含所有已宣告的介面### ###get_declared_classes — 傳回由已定義類別的名字所組成的陣列######這些函數在實際中很少需要用到###
foreach (get_declared_classes() as $class) { $r = new \ReflectionClass($class); }######取得類別###### ###相關函數######get_called_class — 後期靜態綁定類別的名稱,在類別外部使用返回false######get_class — 傳回物件的類別名稱######get_parent_class — 傳回對象或類別的父類別名稱###
get_called_class ( void ) : array get_class ([ object $object = NULL ] ) : string get_parent_class ([ mixed $obj ] ) : string###範例- 拋出異常時取得異常的類別###
throw (new ModelNotFoundException)->setModel(get_called_class());######取得類別成員#########相關函數:## ####get_class_methods — 傳回由類別的方法名稱組成的陣列######get_class_vars — 傳回由類別的預設屬性組成的陣列######get_object_vars — 傳回由物件屬性組成的關聯陣列## ####範例- 取得類別中的所有存取器屬性###
class Foo { public function getFullNameAttribute() { } public function getTextAttribute() { } public static function getMutatorMethods() { preg_match_all('/(?<=^|;)get([^;]+?)Attribute(;|$)/', implode(';', get_class_methods(static::class)), $matches); return $matches[1]; } } Foo::getMutatorMethods() // [ // "FullName", // "Text", // ]
以上是PHP函數庫之類與物件詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!