Я наконец-то придумал супер-элегантный способ сделать это примерно в 5 строках кода, основываясь на том факте, что простой YAML очень похож на Markdown .
Мы начинаем с этого:
---
all:
foo: 1025
bar:
baz: 37628
quux:
a: 179
b: 7
Используйте регулярные выражения (в данном случае в Perl), чтобы удалить начальный ---
, и ставьте дефисы перед ключом в каждой строке:
$data =~ s/^---\n//s;
$data =~ s/^(\s*)(\S.*)$/$1- $2/gm;
Вуаля, Уценка:
- all:
- foo: 1025
- bar:
- baz: 37628
- quux:
- a: 179
- b: 7
Теперь просто запустите его через процессор Markdown:
use Text::Markdown qw( markdown );
print markdown($data);
И вы получите список HTML - чистый, семантический, обратно совместимый:
<ul>
<li>all:
<ul>
<li>foo: 1025</li>
<li>bar:</li>
<li>baz: 37628</li>
<li>quux:
<ul>
<li>a: 179</li>
<li>b: 7</li>
</ul></li>
</ul></li>
</ul>
YUI Treeview может улучшить существующие списки, поэтому мы завершим все это:
<html><head>
<!-- CSS + JS served via YUI hosting: developer.yahoo.com/yui/articles/hosting/ -->
<link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/combo?2.6.0/build/treeview/assets/skins/sam/treeview.css">
<script type="text/javascript" src="http://yui.yahooapis.com/combo?2.6.0/build/yahoo-dom-event/yahoo-dom-event.js&2.6.0/build/treeview/treeview-min.js"></script>
</head><body>
<div id="markup" class="yui-skin-sam">
<!-- start Markdown-generated list -->
<ul>
<li>all:
<ul>
<li>foo: 1025</li>
<li>bar:</li>
<li>baz: 37628</li>
<li>quux:
<ul>
<li>a: 179</li>
<li>b: 7</li>
</ul></li>
</ul></li>
</ul>
<!-- end Markdown-generated list -->
</div>
<script type="text/javascript">
var treeInit = function() {
var tree = new YAHOO.widget.TreeView("markup");
tree.render();
};
YAHOO.util.Event.onDOMReady(treeInit);
</script>
</body></html>
Таким образом, все это работает примерно с 5 строками кода (превратить YAML в Markdown, превратить Markdown в список HTML и поместить этот список HTML в файл HTML шаблона. Сгенерированный HTML постепенно улучшается / разлагается, так как он полностью можно просматривать в браузерах, отличных от JavaScript, в виде простого старого списка.