miniature/di_container 问题修复 & 功能扩展

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

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

miniature/di_container

Composer 安装命令:

composer require miniature/di_container

包简介

A simple implementation of a dependency injection container for PHP-classes and parameters (array, string, numeric). It is consuming array data.

README 文档

README

DiContainer

Warning!

This is still on an experimental level. We don't know if we've got everything together currently. Extensive testing needs to be done as well.

Purpose

This package provides a simple dependecy injection container. It runs on the basis of injected data (PHP-array). The syntax that is used for interpreting the wiring can be manipulated by the injection of the instance of a syntax class.

 
 
 
 
 
 
 

Installation

Using Composer

composer require miniature/di_container

Downloading Package

Unzip to a directory named Miniature. Add to your autoload something like the following:

<?php

function miniature_autoload($class)
{
    $fileName = str_replace('\\', '/', realpath(__DIR__) . '/' . $class ) . '.php';
    if (preg_match('/^(.*\/Miniature)\/(\w+)\/((\w+\/)*)(\w+)\.php/', $fileName)) {
        $newFileName = preg_replace(
            '/^(.*\/Miniature)\/(\w+)\/((\w+\/)*)(\w+)\.php/',
            '$1/$2/src/$3$5.php',
            $fileName
        );
        if (is_file($newFileName)) {
            require $newFileName;
        }
    }
}
spl_autoload_register('miniature_autoload');

Can be that you must adjust the file path concatenation for filePath by setting the relative path in the filepath() statement.

Instantiating

$myDiContainer = (new \Miniature\DiContainer\DiContainer())
    ->readMappings($configArray);

The syntax

Find information about the syntax here.

Overriding the syntax

The syntax can be overridden by incting an implementation of \Miniature\DiContainer\Syntax\MapperAbstract. The class \Miniature\DiContainer\Syntax\MapperSymfonyStyle is an example of how it works.

$myDiContainer = (
    new \Miniature\DiContainer\DiContainer(
            new \Miniature\DiContainer\Syntax\MapperSymfonyStyle()
        )
    )->readMappings($configArray);

Providing the mapping

This is absolutely your choice where the mapping comes from.

We don't recommend using the reader class Miniature\Component\Reader\Config out of context since it might be moved in the future.

If you want the advantages of the Reader and the environment based overrides You might consider the use of the public key in combination of the availability in environments in order to create a grey-box/white-box behaviour component as a provider for your DI-Mapping.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2021-05-25

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固