jameshalsall/object-hydrator 问题修复 & 功能扩展

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

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

jameshalsall/object-hydrator

最新稳定版本:1.2.0

Composer 安装命令:

composer require jameshalsall/object-hydrator

包简介

A simple object hydrator using reflection for constructor or setter based injection.

README 文档

README

Build Status

A simple object hydrator using reflection for constructor or setter based injection.

The hydrator takes an array of raw data and hydrates one or multiple objects of a given class with that data.

Usage

There are two main types of hydrator provided, the ObjectConstructorFromArrayHydrator and the ObjectSetterFromArrayHydrator allowing you to hydrate via a constructor or via setters, respectively.

Constructor hydration

If your object uses constructor injection then you can hydrate your objects using an instance of ObjectConstructorFromArrayHydrator.

Example:

$data = ['name' => 'Frank Turner', 'job_title' => 'Musician'];
$hyrdator = new ObjectConstructorFromArrayHydrator();
$person = $hydrator->hydrate('Person\Employee', $data);

The Person\Employee class would look as follows:

<?php

namespace Person;

class Employee
{
    private $name;
    private $jobTitle;
    
    public function __construct($name, $jobTitle)
    {
        $this->name = $name;
        $this->jobTitle = $jobTitle;
    }
}

Setter hydration

If your object uses setter injection then you can hydrate your objects using an instance of ObjectSetterFromArrayHydrator.

Example:

$data = ['name' => 'Frank Turner', 'job_title' => 'Musician'];
$hyrdator = new ObjectSetterFromArrayHydrator();
$person = $hydrator->hydrate('Person\Employee', $data);

The Person\Employee class would look as follows:

<?php

namespace Person;

class Employee
{
    private $name;
    private $jobTitle;
    
    public function setName($name)
    {
        $this->name = $name;
    }
    
    public function setJobTitle($jobTitle)
    {
        $this->jobTitle = $jobTitle;
    }
}

With the setter hydrator you can pass existing objects to the hydrator as well, rather than class names:

$data = ['name' => 'Frank Turner', 'job_title' => 'Musician'];
$hydrator = new ObjectSetterFromArrayHydrator();
$person = new Person();
$hydrator->hydrate($person, $data);

Hydrating collections

Sometimes you may have an array of arrays, each representing a model's raw data. You can hydrate these in one method call, for example:

$data = [['name' => 'Frank Turner', 'job_title' => 'Musician'], ['name' => 'Steve Jobs', 'job_title' => 'CEO']];
$hydrator = new ObjectSetterFromArrayHydrator();
$hydratedObjects = $hydrator->hydrateCollection('Person\Employee', $data);

NOTE: You cannot pass an object to the hydrateCollection method, it must be either a callable or a string containing the FQCN.

Callable class names

When hydrating an object the first argument that you pass to the hydrate or hydrateCollection method is the fully qualified class name (FQCN) that you wish to create an instance of. Instead of a FQCN you can pass a callable. The callable will receive the raw data ($data) that you pass as the second argument.

Example:

$data = ['name' => 'Frank Turner', 'job_title' => 'Musician'];
$hydrator = new ObjectConstructorFromArrayHydrator();
$person = $hydrator->hydrate(function ($rawData) {
    if ($rawData['job_title' === 'Musician']) {
        return 'Person\Musician';
    }

    return 'Person\Employee';
}, $data);

Roadmap

  • Add factory to improve readability of instantiating hydrators
  • Explore option of adding support for the hydration of nested objects
  • Allow instances of objects to be passed to the hydrator instead of class names

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2014-11-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固