PHPackages                             nick-lai/lazy-object - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. nick-lai/lazy-object

ActiveLibrary

nick-lai/lazy-object
====================

A lightweight lazy object library for PHP 8.4+ project.

1.0.3(1y ago)14MITPHPPHP ^8.4

Since Dec 15Pushed 1y ago1 watchersCompare

[ Source](https://github.com/nick-lai/lazy-object)[ Packagist](https://packagist.org/packages/nick-lai/lazy-object)[ Docs](https://github.com/nick-lai/lazy-object)[ RSS](/packages/nick-lai-lazy-object/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (4)Dependencies (3)Versions (6)Used By (0)

[![Lazy Object](.github/assets/banner.jpg)](https://github.com/nick-lai/lazy-object)

[![PSR-12](https://github.com/nick-lai/lazy-object/actions/workflows/psr-12.yml/badge.svg)](https://github.com/nick-lai/lazy-object/actions/workflows/psr-12.yml)[![Static Analysis](https://github.com/nick-lai/lazy-object/actions/workflows/static-analysis.yml/badge.svg)](https://github.com/nick-lai/lazy-object/actions/workflows/static-analysis.yml)[![Tests](https://github.com/nick-lai/lazy-object/actions/workflows/tests.yml/badge.svg)](https://github.com/nick-lai/lazy-object/actions/workflows/tests.yml)[![Coverage Status](https://camo.githubusercontent.com/9f6a3658fb6ad685f721f1d15c2b9e0231e12a0d47bd56a451e844ce02b988af/68747470733a2f2f636f766572616c6c732e696f2f7265706f732f6769746875622f6e69636b2d6c61692f6c617a792d6f626a6563742f62616467652e7376673f6272616e63683d6d61696e)](https://coveralls.io/github/nick-lai/lazy-object?branch=main)[![PHP Version Require](https://camo.githubusercontent.com/9beb8380bdce9bc60493d7caac06d3ca21c878b9430cce81ba904f6c7733a7d6/68747470733a2f2f706f7365722e707567782e6f72672f6e69636b2d6c61692f6c617a792d6f626a6563742f726571756972652f706870)](https://packagist.org/packages/nick-lai/lazy-object)[![Latest Stable Version](https://camo.githubusercontent.com/53d6c9df6aedeb2f3b3731d76e30211d710ec9e2bdedb765ba9192ea111a5e43/68747470733a2f2f706f7365722e707567782e6f72672f6e69636b2d6c61692f6c617a792d6f626a6563742f76)](https://packagist.org/packages/nick-lai/lazy-object)[![Total Downloads](https://camo.githubusercontent.com/4d70f95126593fda82ad6aba5698815e0b316ba77caf852ca4052a5b7289019b/68747470733a2f2f706f7365722e707567782e6f72672f6e69636b2d6c61692f6c617a792d6f626a6563742f646f776e6c6f616473)](https://packagist.org/packages/nick-lai/lazy-object/stats)

LazyObject
==========

[](#lazyobject)

A lightweight [lazy object](https://www.php.net/manual/en/language.oop5.lazy-objects.php) library for PHP 8.4+ project.

Table of Contents
-----------------

[](#table-of-contents)

- [LazyObject](#lazyobject)
    - [Table of Contents](#table-of-contents)
    - [Requirements](#requirements)
    - [Installation](#installation)
    - [Usage](#usage)
        - [`LazyObjectTrait`](#lazyobjecttrait)
        - [`LazyObjectFactory`](#lazyobjectfactory)
        - [`LazyObjectHelper`](#lazyobjecthelper)
    - [License](#license)

Requirements
------------

[](#requirements)

LazyObject requires PHP &gt;= 8.4.0.

Installation
------------

[](#installation)

```
composer require nick-lai/lazy-object
```

Usage
-----

[](#usage)

### `LazyObjectTrait`

[](#lazyobjecttrait)

```
use NickLai\LazyObject\LazyObjectTrait;

class NormalClass
{
    use LazyObjectTrait;

    public function __construct(
        public string $name,
    ) {
        echo 'Initialized.' . PHP_EOL;
    }
}

// Output: Initialized.
$normalClass = new NormalClass('Tom');
// Output: Hi, Tom!
echo "Hi, {$normalClass->name}!" . PHP_EOL;

$lazyObject = NormalClass::createLazyObject('Jerry');
// Outputs:
// Initialized.
// Hi, Jerry!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = NormalClass::createLazyObjectByArgumentsGetter(fn () => [
    'name' => 'Spike',
]);
// Outputs:
// Initialized.
// Hi, Spike!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = NormalClass::createLazyObjectByInitializer(fn ($object) => $object->__construct(
    name: 'Tyke',
));
// Outputs:
// Initialized.
// Hi, Tyke!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;
```

### `LazyObjectFactory`

[](#lazyobjectfactory)

```
use NickLai\LazyObject\LazyObjectFactory;

class NormalClass
{
    public function __construct(
        public string $name,
    ) {
        echo 'Initialized.' . PHP_EOL;
    }
}

$factory = LazyObjectFactory::create(NormalClass::class);

$lazyObject = $factory->createLazyObject('Jerry');
// Outputs:
// Initialized.
// Hi, Jerry!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = $factory->createLazyObjectByArgumentsGetter(fn () => [
    'name' => 'Spike',
]);
// Outputs:
// Initialized.
// Hi, Spike!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = $factory->createLazyObjectByInitializer(fn ($object) => $object->__construct(
    name: 'Tyke',
));
// Outputs:
// Initialized.
// Hi, Tyke!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;
```

### `LazyObjectHelper`

[](#lazyobjecthelper)

```
use NickLai\LazyObject\LazyObjectHelper;

class NormalClass
{
    public function __construct(
        public string $name,
    ) {
        echo 'Initialized.' . PHP_EOL;
    }
}

$lazyObject = LazyObjectHelper::createLazyObject(
    className: NormalClass::class,
    name: 'Jerry',
);
// Outputs:
// Initialized.
// Hi, Jerry!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = LazyObjectHelper::createLazyObjectByArgumentsGetter(
    className: NormalClass::class,
    argumentsGetter: fn () => [
        'name' => 'Spike',
    ],
);
// Outputs:
// Initialized.
// Hi, Spike!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;

$lazyObject = LazyObjectHelper::createLazyObjectByInitializer(
    className: NormalClass::class,
    initializer: fn ($object) => $object->__construct(
        name: 'Tyke',
    ),
);
// Outputs:
// Initialized.
// Hi, Tyke!
echo "Hi, {$lazyObject->name}!" . PHP_EOL;
```

License
-------

[](#license)

LazyObject is released under the [MIT](LICENSE) License. See the bundled LICENSE file for details.

###  Health Score

31

—

LowBetter than 68% of packages

Maintenance42

Moderate activity, may be stable

Popularity5

Limited adoption so far

Community9

Small or concentrated contributor base

Maturity59

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 77.8% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~1 days

Total

4

Last Release

506d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/10176232c981785d06e3ea493f7c5666ebaf4d75e2c251be3f0a371a4e8f317c?d=identicon)[nick-lai](/maintainers/nick-lai)

---

Top Contributors

[![nick-lai](https://avatars.githubusercontent.com/u/7104395?v=4)](https://github.com/nick-lai "nick-lai (14 commits)")[![github-actions[bot]](https://avatars.githubusercontent.com/in/15368?v=4)](https://github.com/github-actions[bot] "github-actions[bot] (4 commits)")

---

Tags

lazy-objectphpphp-lazy-objectlazylazy object

###  Code Quality

TestsPHPUnit

Static AnalysisPHPStan

Code StylePHP\_CodeSniffer

Type Coverage Yes

### Embed Badge

![Health badge](/badges/nick-lai-lazy-object/health.svg)

```
[![Health](https://phpackages.com/badges/nick-lai-lazy-object/health.svg)](https://phpackages.com/packages/nick-lai-lazy-object)
```

###  Alternatives

[rybakit/twig-deferred-extension

An extension for Twig that allows to defer block rendering.

1092.7M3](/packages/rybakit-twig-deferred-extension)[cerbero/lazy-json

Framework-agnostic package to load JSONs of any dimension and from any source into Laravel lazy collections.

254309.8k1](/packages/cerbero-lazy-json)[cerbero/lazy-json-pages

Framework-agnostic package to load items from any paginated JSON API into a Laravel lazy collection via async HTTP requests.

19697.4k](/packages/cerbero-lazy-json-pages)[alexandre-daubois/lazy-stream

Write data to streams, only when it is really needed to.

755.7k](/packages/alexandre-daubois-lazy-stream)[simonvomeyser/commonmark-ext-lazy-image

Adds support for lazy images to the phpleague/commonmark markdown parser package

1821.3k1](/packages/simonvomeyser-commonmark-ext-lazy-image)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
