这是我在这里的第一个问题,我将尽可能地澄清它。
我是一个初学者,我正在通过lynda - 当我到达这个部分时,超越PHP MySQL课程。
代码工作得很好,我只需要更好地解释自己对代码中注释的行。
require_once('database.php');
class User {
public $id;
public $username;
public $password;
public $first_name;
public $last_name;
public static function find_all() {
return self::find_by_sql("SELECT * FROM users");
}
/////
public static function find_by_sql($sql="") {
global $database;
$result_set = $database->query($sql);
$user_array = array();
while ($row = $database->fetch_array($result_set)) {
$user_array[] = self::instantiate($row);
}
return $user_array;
}
我最近明白的最后几行:)
private static function instantiate($row) {
$user = new self;
foreach($row as $attribute=>$value){
if($user->has_attribute($attribute)) {
$user->$attribute = $value; /// THIS LINE BUGS ME
}
}
return $user;
}
private function has_attribute($attribute) {
$user_vars = get_object_vars($this);
return array_key_exists($attribute, $user_vars);
}
}
所以我认为我不理解array_key_exists
返回TRUE或FALSE,在我的情况下是真的,但是$users->$attributes =$value ;
行对我没有意义,
因此,我检查来自对象
的fetch数组MATCH变量名的键if($user->has_attribute($attribute)) { //and then this is true,perform nxt line
$user->$attribute = $value; // i got match of attribute above,how does it put values in $user_vars???
我知道它说“如果用户具有与该获取数组中的键相同的属性然后放入该属性$ value的相同属性值,但我只是看不到当我从未返回对象变量时它是如何完成的
感谢您的时间!
编辑: 类变量名称等于数据库
中column_names的名称答案 0 :(得分:0)
将此行更改为
// $user->$attribute = $value;
$user->{$attribute} = $value;
我希望这会起作用
答案 1 :(得分:0)
User
类包含公共属性$id
,$username
,$password
等。这意味着您可以按以下格式为属性指定值:
$u = new User;
$u->id = 123;
$u->username = 'username';
并使用动态属性名称:
$prop = 'id';
$u->$prop = 123;
$prop = 'username';
$u->$prop = 'username';
这就是您不理解的行中发生的事情:
if ($user->has_attribute($attribute)) {
$user->$attribute = $value;
has_attribute
方法使用$user
函数获取get_object_vars
对象的所有属性。后者将对象属性作为数组提取:
$user_vars = get_object_vars($this);
/* i.e.
$user_vars = array (
'id' => ...,
'username' => ...,
...
);
*/
然后has_attribute
方法检查属性数组中是否存在给定的$attribute
键:
return array_key_exists($attribute, $user_vars);
如果存在(true
),$attribute
属性将分配给$value
。