get_object_vars() 返回对象的可访问属性数组,用于将对象转为数组进行遍历、过滤或导出。在类外部仅返回 public 属性,内部可访问所有属性,支持与数组函数结合操作。

get_object_vars() 是 PHP 中用于获取对象的可访问属性的函数,它返回一个关联数组,包含对象中所有可在当前作用域访问的 public 属性。这个函数并不直接用于数组,而是用于对象。但它的返回结果是一个数组,因此可以与数组操作结合使用。
get_object_vars() 的基本用法
该函数接收一个对象作为参数,返回该对象的 public 属性组成的关联数组。如果在类方法内部调用,还能访问 protected 和 private 属性(取决于调用上下文)。
class User {
public $name = 'John';
protected $age = 30;
private $email = 'john@example.com';
public function getVars() {
return get_object_vars($this); // 在类内部,能访问所有属性
}
}
$user = new User();
var_dump(get_object_vars($user)); // 只输出 public 属性: name
var_dump($user->getVars()); // 输出所有属性: name, age, email
与数组操作结合的常见场景
由于 get_object_vars() 返回的是数组,你可以像处理普通数组一样对其进行遍历、过滤、合并等操作。
- 遍历对象属性:将对象转换为数组后,使用 foreach 遍历所有 public 属性。
- 数据导出:将对象数据转为数组格式,便于 JSON 编码或存储到数据库。
- 属性过滤:结合 array_filter 对对象属性进行条件筛选。
- 合并对象数据:将多个对象的属性合并为一个数组。
$user = new User();
$props = get_object_vars($user);
foreach ($props as $key => $value) {
echo "$key: $value\n"; // 输出: name: John
}
// 转为 JSON
echo json_encode($props); // {"name":"John"}
注意事项
该函数只处理对象,传入非对象会返回 false。同时注意访问权限对结果的影响。
SmartB2B 是一款基于PHP、MySQL、Smarty的B2B行业电子商务网站管理系统,系统提供了供求模型、企业模型、产品模型、人才招聘模型、资讯模型等模块,适用于想在行业里取得领先地位的企业快速假设B2B网站,可以运行于Linux与Windows等多重服务器环境,安装方便,使用灵活。 系统使用当前流行的PHP语言开发,以MySQL为数据库,采用B/S架构,MVC模式开发。融入了模型化、模板
立即学习“PHP免费学习笔记(深入)”;
- 在对象外部调用时,只能获取 public 属性。
- 传入 null 或非对象类型会导致警告。
- 对于动态属性(PHP 允许给对象动态添加属性),也会被包含在结果中。
基本上就这些。get_object_vars() 不是用于数组的函数,但它把对象“变成”数组,从而方便使用数组函数处理对象数据。理解其作用域限制和返回结构,能更好结合数组功能使用。










