为了账号安全,请及时绑定邮箱和手机立即绑定

为什么这样却无法输出类b的属性?

为什么这样却无法输出类b的属性?

PHP
杨__羊羊 2023-04-17 23:19:59
class a{//主要功能是连接数据库,取出表中字段,将字段定义为子类属性,想以这种方式实现ActiveRecord     function doQuery($dbname, $table){        $fields = mysql_list_fields($dbname, $table);        $num = mysql_num_fields($fields);        $keys = array();        for($i=0; $i<$num; $i++){             array_push($keys, mysql_fields_name($fields);         }        return $keys;      } }class b{      function bind($data){         foreach($data as $key=>$value){             $this->$value = null;          }         print_r(get_class_vars(get_class($this));      } }
查看完整描述

2 回答

?
互换的青春

TA贡献1797条经验 获得超6个赞

get_class_vars — Get the default properties of the class

动态定义的属性是不会被这个函数打出来的 ...

如果你需要列出一个类的所有属性 ... 一段小技巧可以帮助到你 ...

<?phpclass b {    public function bind( $data ) {        foreach ( $data as $key => $value )            $this->$value = null;        /* just make an array to output like you want ... */
        $ret = [];        /* no need to do type conversion here ... php will done for us ... */
        foreach( $this as $key => $null_of_course )            $ret[] = $key;        /* miracle time ... */
        print_r( $ret );

    }

}

(new b)->bind( [ 
    'aa'    =>  'bb',    'cc'    =>  'dd'
    ] );

或者更简单的写法 ... 需要手动转化一下类型 ...

 $ret = array_keys( (array) $this );


查看完整回答
反对 回复 2023-04-20
?
婷婷同学_

TA贡献1844条经验 获得超8个赞

public function doQuery($table){			$fields = mysql_list_fields($this->dbName, $table);			$keys = array();			$num = mysql_num_fields($fields);			for ($i=0; $i < $num; $i++) { 
				array_push($keys, mysql_field_name($fields, $i));
			}			foreach ($keys as $key => $value) {				$this->$value = $value;
			}			print_r($keys);
			Echo '<pre>';			print_r(get_class_vars(get_class($this)));

		}


查看完整回答
反对 回复 2023-04-20
  • 2 回答
  • 0 关注
  • 118 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信