ホームページ > バックエンド開発 > PHPチュートリアル > PHP5 ゲッター/セッター基本クラスを実装するコード_PHP チュートリアル

PHP5 ゲッター/セッター基本クラスを実装するコード_PHP チュートリアル

WBOY
リリース: 2016-07-21 15:57:22
オリジナル
823 人が閲覧しました

PHP3 も PHP4 もクラスはありますが、そのクラス定義は本当にまともではなく、その効率は非常に恥ずかしいものですが、情報によると、PHP5 はオブジェクト指向のサポートを再構築しました。完全なオブジェクト指向ではありませんが、使用できます。誰かに会いましょう。
PHP5 で追加されたクラスメンバー許可キーワードは非常に優れていると感じましたが、フィールドのゲッターとセッターを定義する便利な方法がないようです。従来の方法は次のように定義されます:

class a
{
public function get_field() { return $this->$field; }
public function set_field($value); ;field = $value ; }
}

実装は簡単ですが、正直に言うと、フィールドに対してこのようなコードを記述するのは非常に面倒です。 。
そこで、それを解決し、型制限などを簡単に定義する、より便利な方法はないかと考えました。
ずっといじっています(詳しくないので仕方ありません)。)、终出一类来解决这个问题:

class abstract_entity
{
private $fields;
private $sys_type = array(
「bool」 => "",
「array」 => "",
"double" => ""
"float" =& gt; "",
"int " => "",
"integer" =>> "",
"long " => "",
"null" => "",
"object" => "",
「本物」 " => "",
"リソース" =>> "",
"文字列" => ""
// 「混合」 と 「数値」
);
protected function __construct($fields)
{
/**********************************
* $fields = array(
* "id" = array(
* "allow_null " = false,
* 「値」 = 1,
* 「型」 = 「int」
* );
* );
*********************************/

$this->fields = $fields;
}
public __get($key)
{
if(array_key_exists($key, $this->fields))
{
return $this->fields[$key] ["値"];
}
else
{
throw new Exception("该属性不存在");
}
}
public __set($key, $value)
{
if(array_key_exists($key, $this->fields))
{ $allow_null = $this->フィールド[$key][ "ヌルを許可します"];
$type = $this->fields[$key]["type"];
if(array_key_exists($type, $this->sys_type))
{
$fun = create_function('$value', "return is_$type($value);");
if(@$fun($value))
{
$this->fields[$key]["value"] = $value;
}
else if($allow_null && is_null($value))
{
$this->fields[$key]["value"] = NULL; { . $type . "タイプ");
}
else if($type == "mixed")

if(!is_null($value) )
{
$this->fields[$key]["value"] = $value;
}
else if($allow_null)
{
$this->fields[$key]["value"] = N完全;
}} else
}
else if($type == "number")
{
if(is_int($value) || is_float($value))
{
$this->fields[$key]["value "] = $value;
}
else if(is_null($value) && $allow_null)
{
$this->fields[ $key]["value"] = NULL; { . $type . "タイプ");

}
else
{
if(class_exists($type) || interface_exists($type))
{ if(is_subclass_of($value, $type))
{
$this->fields[$key]["value "] = $value;
else if(is_null($value) && $allow_null)
{ $this->fields[$key]["value"] = NULL;
else
{
throw new Exception("タイプが正しくありません、必ず「 . $type . 「タイプ」);

}
else if(is_null($value) && $allow_null)
{ $this->fields[$key]["value"] = NULL;
}
}
else
{
throw new Exception("该属性不存在");
}
}
}

1 つの動作形式の配列を指定することにより、そのフィールドの種類、NULL 値を許可するかどうか、および承認値を簡単に決定できます。

测试代码如下:

class test extends abstract_entity
{
public function __construct()
{

$define = array(
"id " => array(
"allow_null" => false,
"value " => 1,
"type" => "int"
),
"name" => array(
"allow_null" =& gt; false,
「値」 => "abc",
」 type" => "string"
),
"gender" => array(
"allow_null" => false,
"value" => true、
「タイプ」 => 「ブール値」
,
"ins" => array(
"allow_null" => false,
"value" => $this,
「タイプ」 => 「テスト」
)、

「ins1」 => array(
「allow_null」 => true,
「value」 => $this,
「type」 => 「test」
),
「ins2」 => array(
「allow_null」 => true、
「値」 => NULL、
「タイプ」 => "config_media_type"
)
);

parent::__construct($define);
}
}
$a = 新しい テスト();
$a->id = 123;
eche $a->id;
echo $a->ins1;
$a->ins1 = NULL;
echo is_null($a->ins1);

ここではゲッターとセッターを完了しましたが、時間の経過により読み取り専用の機能が廃止されたため、その機能は再追加され、标识它能は変更できません

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/317883.html技術記事 PHP3 と PHP4 は両方ともクラスを持っていますが、それらのクラス定義は実際にはまともではなく、その効率性は非常に恥ずかしいものですが、データによると、PHP5 は完全指向ではないものの、オブジェクト指向のサポートを再構築したとのことです...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート