nabeghe / text-binder
A lightweight PHP text binding library with placeholder replacement and chained function support.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/nabeghe/text-binder
Requires
- php: >=7.4
- ext-json: *
Requires (Dev)
- phpunit/phpunit: 9.6
This package is auto-updated.
Last update: 2026-02-03 00:07:51 UTC
README
A lightweight and flexible text binding engine with support for chained placeholder functions.
TextBinder is a small PHP library for binding variables into text using placeholders, with the ability to apply chained functions to transform values on the fly. It is designed to be simple, extensible, and dependency-free.
Features
- Simple placeholder replacement using
{variable}syntax - Chained function support:
{variable.func1.func2}(multiple functions in sequence) - Built-in helper functions (
exists,ok) - Support for custom user-defined functions
- Automatic normalization of function outputs
- Zero dependencies (except
ext-json) - Compatible with PHP 7.4+
🫡 Usage
🚀 Installation
You can install the package via composer:
composer require nabeghe/text-binder
Or manually include the TextBinder.php if you want to keep it old school.
Basic Example
use Nabeghe\TextBinder\TextBinder; $binder = new TextBinder(); $text = 'Hello {name}!'; echo $binder->render($text, [ 'name' => 'Elsa' ]);
Output:
Hello Elsa!
Chained Functions (Multiple Functions in Sequence)
TextBinder allows applying multiple functions to a single placeholder using dot notation:
$binder->addFunc('upper', fn($v) => strtoupper($v)); $binder->addFunc('surround', fn($v) => ">>$v<<"); $text = 'Transformed: {name.upper.surround}'; echo $binder->render($text, [ 'name' => 'world' ]);
Output:
Transformed: >>WORLD<<
You can chain any number of functions, mixing built-in, custom, or native PHP functions:
$text = 'Check: {username.exists.strlen}'; echo $binder->render($text, [ 'username' => 'admin' ]);
Output:
Check: 1
Missing Variables
By default, missing variables are replaced with an empty string:
$text = 'Hello {name}'; echo $binder->render($text, []);
You can disable this behavior:
echo $binder->render($text, [], false);
Custom Functions
You can register your own functions and use them in placeholders:
$binder->addFunc('upper', function ($value) { return strtoupper($value); }); $text = 'Hello {name.upper}'; echo $binder->render($text, [ 'name' => 'world' ]);
Output:
Hello WORLD
Native PHP Functions
If a registered function is not found, TextBinder will automatically fall back to native PHP functions when available:
$text = 'Length: {name.strlen}'; echo $binder->render($text, [ 'name' => 'TextBinder' ]);
📖 License
Licensed under the MIT license, see LICENSE.md for details.