asika/object-metadata 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

asika/object-metadata

最新稳定版本:1.0

Composer 安装命令:

composer require asika/object-metadata

包简介

PHP Global Object Metadata Management

README 文档

README

GitHub GitHub Workflow Status Packagist Downloads Packagist Version

Object Metadata is a package to help developer manage custom global object metadata. This package use WeakMap to control the data mapping with object instances.

Installation

composer require asika/object-metadata

Getting Started

Basic usage:

use Asika\ObjectMetadata\ObjectMetadata; // Create any objects $obj = new ArticleEntity(); // Get global main instance $meta = ObjectMetadata::getInstance(); // Set custom metadata $meta->set($obj, 'foo', 'Hello'); // Now you can get the data everywhere if this object still exists and not destruct yet ObjectMetadata::getInstance()->get($obj, 'foo'); // Hello // Available methods $meta->get($obj, 'key'); $meta->set($obj, 'key', 'value'); $meta->has($obj, 'key'); $meta->remove($obj, 'key'); $meta->getMetadata($obj, 'key'); // array $meta->setMetadata($obj, 'key', $data);

Use wrapper:

$obj = new ArticleEntity(); $meta = ObjectMetadata::getInstance(); $metaWrapper = $meta->wrapper($obj); $metaWrapper->set('foo', 'Hello'); $metaWrapper->get('key'); $metaWrapper->has('key'); $metaWrapper->remove('key'); $metaWrapper->all(); // Array Access $metaWrapper['key'] = 'value'; // If object destructed, getting metadata will be NULL unset($obj); $metaWrapper->get('foo'); // NULL

Scope

The ObjectMetadata is able to separate different scopes.

$meta = ObjectMetadata::getInstance('main'); // Main scope $appMeta = ObjectMetadata::getInstance('app'); $dbMeta = ObjectMetadata::getInstance('db');

What is The Real Usage

The useful case for this package is that we can make some entity object or value object to be a rich object. for example, if a ORM uses data-mapper pattern, their entity object will be a anemic object which may not keep the ORM instance.

$item = new Article(); $item = $orm->createOne($item); // This item will only contains pure data

If the ORM use this package to make themselves as entity metadata, we can make the Article entity as a rich object and has the capacity to all ORM to get another objects.

$orm->on('entity.prepare', function (object $entity, ORM $orm) { ObjectMetadata::getInstance('db')->set($entity, 'orm', $orm); }); class Article { // ... // Article can use ObjectMetadata to get ORM instance. public function getComments() { $orm = ObjectMetadata::getInstance('db')->get($this, 'orm'); return $orm->from(Comment::class) ->where('article_id', $this->getId()) ->all(); } } // Now we can test it $article = $orm->createEntity(Article::class); $item = $orm->createOne($item); // Article is able to call ORM to get another items from DB $item->getComments(); $item->getAuthor(); $item->getTags();

统计信息

  • 总下载量: 6.31k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 3
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固