justinskolnick/key-value
最新稳定版本:1.0.0
Composer 安装命令:
composer require justinskolnick/key-value
包简介
KeyValue provides an interface for managing associative arrays as a collection of key-value pairs.
README 文档
README
KeyValue provides an interface for managing associative arrays as a collection of key-value pairs.
It handles common but often complex operations like confirming membership and overwriting nested values in multi-dimensional arrays. Like so:
$collection = new KeyValue(); $collection->set( 'id', 'bffc4d08-1750-41a7-9fdd-345187eb9ff2' ); echo $collection->get( 'id' ); // 'bffc4d08-1750-41a7-9fdd-345187eb9ff2'
KeyValue is one of a number of tools I'm hoping to extract from older, larger projects.
Installation
To install this library with Composer, type:
composer require justinskolnick/key-value
Local installation is possible using the repositories block of your composer.json. For instance:
{
"repositories": [
{
"type": "path",
"url": "./packages/justinskolnick/key-value",
"options": {
"symlink": true
}
}
],
"require": {
"justinskolnick/key-value": "*"
}
}
Usage
KeyValue collections are associative arrays, with mixed-type values saved at keys. Keys must be strings:
$id = $collection->get( 'id' );
If a KeyValue item's value is an array, the key can include a slash to access a value at the second level of the array:
$timestamp = $collection->get( 'created/timestamp' );
To get started, initiate a new KeyValue collection:
$collection = new KeyValue();
A collection can also be initiated with values:
$collection = new KeyValue( [ 'id' => 'bffc4d08-1750-41a7-9fdd-345187eb9ff2', 'phone_number' => 8675309, 'was_saved' => false, ] );
Set a value or many values:
$collection->set( 'id', 'bffc4d08-1750-41a7-9fdd-345187eb9ff2' ); $collection->setMany( [ 'id' => 'bffc4d08-1750-41a7-9fdd-345187eb9ff2', 'phone_number' => 8675309, 'was_saved' => false, 'created' => [ 'readable' => 'November 7, 2025', 'timestamp' => '2025-11-07 01:23:45', ], ] );
Confirm that any values have been set:
if ( $collection->hasAny() ) { return true; }
Confirm that a key exists, or that a value has been set at a given key:
if ( $collection->has( 'id' ) ) { return true; } if ( $collection->hasValueAt( 'id' ) ) { return true; }
Get a value for a given key:
$id = $collection->get( 'id' );
Get all values for all keys, or only the keys, or only the values:
$all = $collection->getAll(); $keys = $collection->getKeys(); $values = $collection->getValues();
Remove an item (and confirm the deletion):
if ( $collection->delete( 'id' ) ) { echo $collection->get( 'id' ); // null }
Reset the collection to null (and confirm the reset):
$collection = new KeyValue( [ 'ducks' => 3, 'dogs' => 4, 'horses' => 2, ] ); $collection->set( 'dogs', 6 ); if ( $collection->reset() ) { echo $collection->get( 'dogs' ); // 4 }
Reset the collection to null (and confirm the reset):
$collection = new KeyValue( [ 'ducks' => 3, 'dogs' => 4, 'horses' => 2, ] ); if ( $collection->reset( true ) ) { echo $collection->get( 'dogs' ); // null }
Confirm the collection is empty:
if ( $collection->isEmpty() ) { return true; }
Confirm the collection is a non-null empty array:
$collection = new KeyValue( [] ); if ( $collection->isEmpty( true ) ) { return true; }
Confirm the collection is null (such as on init or after a reset):
if ( $collection->isNull() ) { return true; }
Style
Readers will note that the code, tests, and examples in this README don't meet the requirements of PSR-2 or PSR-12. Instead, they follow conventions I adopted a long time ago to help me scan PHP code. While this personal style is expected to be followed in PRs on this repository, it's not a requirement of use.
License
Copyright (c) 2025 Justin Skolnick. MIT License.
统计信息
- 总下载量: 11
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-11-24