1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
<html>
<head><title>Outline Tree Using Jstemplates</title>
<script src="../util.js" type="text/javascript"></script>
<script src="../jsevalcontext.js" type="text/javascript"></script>
<script src="../jstemplate.js" type="text/javascript"></script>
<script type="text/javascript">
// Hierarchical data:
var tplData =
{ title: "Jstemplates", items: [
{ title: "Using Jstemplates", items: [
{ title: "The Jstemplates Module"},
{ title: "Javascript Data"},
{ title: "Template HTML"},
{ title: "Processing Templates with Javascript Statements"}
]
},
{ title: "Template Processing Instructions", items: [
{ title: "Processing Environment" },
{ title: "Instruction Attributes", items: [
{title: "jscontent"}, {title: "jsselect"}, {title: "jsdisplay"},
{title: "transclude"},{title: "jsvalues"}, {title: "jsskip"}, {title: "jseval"}
]}
]}
]};
var PEG_NAME = 'peg';
var TEMPLATE_NAME = 'tpl';
// Called by the body onload handler:
function jsinit() {
pegElement = domGetElementById(document, PEG_NAME);
loadData(pegElement, TEMPLATE_NAME, tplData);
}
function loadData(peg, templateId, data) {
// Get a copy of the template:
var templateToProcess = jstGetTemplate(templateId);
// Wrap our data in a context object:
var processingContext = new JsEvalContext(data);
// Process the template
jstProcess(processingContext, templateToProcess);
// Clear the element to which we'll attach the processed template:
peg.innerHTML = '';
// Attach the template:
domAppendChild(peg, templateToProcess);
}
</script>
<link rel="stylesheet" type="text/css" href="css/maps2.deb.css"/>
</head>
<body onload="jsinit()">
<!--
This is the div to which the instantiated template will be attached.
-->
<div id="peg"></div>
<!--
A container to hide our template:
-->
<div style="display:none">
<!--
This is the template div. It will be copied and attached to the div above with:
var apt = jstGetTemplate('apt');
appendChild(panel, apt)
-->
<div id="tpl">
<span jscontent="title">Outline heading</span>
<ul jsdisplay="items.length">
<li jsselect="items">
<!--Recursive tranclusion: -->
<div transclude="tpl"></div>
</li>
</ul>
</div>
</div>
</body>
</html>
|