定制 roke22/array-to-object-factory 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

roke22/array-to-object-factory

最新稳定版本:v1.0.0

Composer 安装命令:

composer require roke22/array-to-object-factory

包简介

Array to object that automatically maps array index to object constructor parameters

README 文档

README

How to install?

composer require roke22/array-to-object-factory

What is array to object factory?

This is a utility that help you to create a class and all dependencies of the class without mapping the values.

All objects are create using the construct methods so the data have to acomplish the validations you have.

Unique requisite is that the index of the values of the array have to be organize in the same level of hierarchy.

It have declare strict types so value 1 is not the same as '1'. PHP is not going to try to convert the int 1 to string '1'. In that case you will get a TypeError exception.

Example

class SimpleClass
{
    protected string $name;
    protected bool $isActive;

    public function __construct(string $name, bool $isActive)
    {
        $this->name = $name;
        $this->isActive = $isActive;
    }
}

You can create this class doing this:

$data = [
    'name' => 'John Doe',
    'is_active' => false
];

$object = ArrayToObject::make($data, SimpleClass::class);

Array index are transformed to snake, camel and studly case to find the match between the array data and construct params of the object.

You can limit the conversion parssing a third parameter like this:

$object = ArrayToObject::make($data, SimpleClass::class, ArrayToObject::SNAKE);

Or even don't convert any data:

$object = ArrayToObject::make($data, SimpleClass::class, ArrayToObject::NONE);

Possible values are:

ArrayToObject::ALL // By default
ArrayToObject::SNAKE
ArrayToObject::CAMEL
ArrayToObject::STUDLY
ArrayToObject::NONE

Getting the original $data array as example:

$data = [
    'name' => 'John Doe',
    'is_active' => false
];

Array to object factory transform in the next array:

$data = [
    'name' => 'John Doe',
    'is_active' => false,
    'isActive' => false,
    'IsActive' => false,
];

If some of the index conversion exists in the original array the data will be override and the object can be construct with wrong data, to solve this you can force the conversion type to NONE or only the annotation you need

Example Complex class

class Classroom
{
    protected int $number;
    protected Course $course;

    public function __construct(int $number, Course $course)
    {
        $this->number = $number;
        $this->course = $course;
    }
}

class Course
{
    protected string $name;

    public function __construct(string $name)
    {
        $this->name = $name;
    }
}

$data = [
    'number' => 1,
    'course' => [
        'Maths'
    ]
];

$result = ArrayToObject::make($data, Classroom::class);

More examples

You can view the test folders to view some examples of collections and more complex class.

Feel free to report any issue and do any pull request to improve the package.

Thank you.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-08-29

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固