ayeo/parser
Composer 安装命令:
composer require ayeo/parser
包简介
Replace placeholders with proper data
关键字:
README 文档
README
Simple placeholder parser
Parser replaces specific placeholders with proper data.
Basic usage
Let's take a look at the simplest possible example:
$parser = new Parser; $string = "Hello {{name}}!"; $parser->parse($string, ['name' => 'Nikola Tesla']); //returns: Hello Nikola Tesla!
Of course you may use object instead of primitive array
$parser = new Parser; $customer = new Customer; $customer->name = 'Nikola Tesla'; $string = "Hello {{customer.name}}!"; $parser->parse($string, ['customer' => $customer]); //returns: Hello Nikola Tesla!
Parser is smart enough to access private properties using getters.
It also supports nested objects as well
$parser = new Parser; $customer = new Customer; $address = new Address('Green Alley', 12, 'London', 'LN4 4GD', 'United Kingdom'); $customer->setAddress($address); $string = "{{customer.address.street}}"; $parser->parse($string, ['customer' => $customer]); //returns: Green Alley
Nested array are also welcome
$parser = new Parser(); $data = ['user' => ['supervisor' => ['name' => 'Harry']]]; $parser->parse('Hi {{user.supervisor.name}}!', $data); //returns: Hi Harry!
Use custom embrace string
By default Parser uses "{{" as open string and "}}" as close string. You can set your own embrace strings using method
$parser = new Parser(); $parser->setEmbraceStrings("*", "*"); $parser->parse("All *fruit* are *color*.", ["fruit" => "oranges", "color" => "orange"]); //returns "All oranges are orange."
or using constructor
$parser = new Parser("", "*", "*");
Note, embrace strings can not contains # char.
Formatting
Sometimes you need to use additional formatting for specific objects. The great example is DateTime. The best way to achieve this goal is use adapter pattern (or decorator) for your object. The parser shouldnt be able to do that for you.
统计信息
- 总下载量: 22.43k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-09-10