louis-dj/xml-template
最新稳定版本:v1.0.0
Composer 安装命令:
composer require louis-dj/xml-template
包简介
Xml templating engine for dynamic xml string generation in php
README 文档
README
Generate dynamic xml strings using templated xml files.
Motivation
Avoid building dynamic xml strings with messy string concatenations in your code.
Avoid adding static boilerplate elements when using a useful package like ArrayToXml.
Usage
Install the package with composer:
composer install louis-dj/xml-template
Create an xml file with templating directives
<xml> {{ var randomVar }} </xml>
Import the package and convert with the replaceWith method
<?php use LouisDj\XmlTemplate\XmlTemplate; $template = new XmlTemplate('./test.xml'); $output = $template->replaceWith(['randomVar' => 'Some string']);
Absolute filepaths AND relative filepaths(relative to cwd) are supported
Features
- Minified: The
replaceWithmethod has an optional boolean parameterminifiedto remove all newline characters from the xml - Object & Array compatibility: The associative array passed to the
replaceWithmethod can contain string keys OR objects with field names corresponding to the variables OR both - See the syntax below for full feature set
Syntax & Rules
- All directives must be enclosed in
{{}}and contain a space on the inside of both pairs - Variable names use a global scope, even variables defined in
foreachdirectives - All directives can be freely nested as long as it is property closed with an
enddirective if,else,foreachandenddirectives must be on their own line, but may be indented.
Variable Directives
<xml>{{ var myVariableName }}</xml>
If statements
- All
ifstatements must be closed by anenddirective
{{ if booleanValue }} <conditionalcontent></conditionalcontent> {{ end }}
If else statements
- All
if elsestatements must be closed by anenddirective
{{ if booleanValue }} <True></True> {{ else }} <False></False> {{ end }}
Foreach statements
- All
foreachstatements must be closed by anenddirective
{{ foreach countableVariable }} <item>This will appear n=(length of countableVariable) times</item> {{ end }}
Foreach as statements
- All
foreach asstatements must be closed by anenddirective
{{ foreach arrayVariable as arrayItem }} <item>The array contains: {{ var arrayItem }}</item> {{ end }}
Attribute access
- The dot (.) operator works to access associative array keys' values too.
<xml>{{ var someObjectOrArray.attrName }}</xml>
Pass in Objects to the replaceWith method
- View
tests/Test.phpfor more detailed use cases
$subbed = $template->replaceWith([ 'book' => new Book('The Great Gatsby', '1234') ]);
Testing
Testing is done with phpunit and all tests are contained in the tests/ directory.
Run tests with:
vendor/bin/phpunit
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-03-06