我正在开发一个dojo
包含Dialog
. 内容Dialog
作为文本从模板html
文件加载。我遇到的问题是在将 dom 节点添加到 domDialog
之前,我需要将 dom 节点添加到内容Dialog
中。
这是我的模板(DialogContent.html
):
<div>
<table>
<tbody>
<tr>
<td>
<label for="printTitle">Map Title:</label>
</td>
<td>
<input id="printTitle" data-dojo-type="dijit/form/TextBox" name="title" />
</td>
</tr>
<tr>
<td>
<label for="printOrientation">Page Orientation:</label>
</td>
<td>
<select id="printOrientation" data-dojo-type="dijit/form/FilteringSelect" name="orientation">
<option value="Letter ANSI A Landscape">Landscape</option>
<option value="Letter ANSI A Portrait">Portrait</option>
</select>
</td>
</tr>
<tr>
<td>
<label for="printUnits">Scale Bar Units:</label>
</td>
<td>
<select id="printUnits" data-dojo-type="dijit/form/FilteringSelect" name="units">
<option value="Miles">Miles</option>
<option value="Kilometers">Kilometers</option>
<option value="Feet">Feet</option>
<option value="Meters">Meters</option>
</select>
</td>
</tr>
<tr>
<td>
<label for="printLayers">Layers to Include in Legend:</label>
</td>
<td>
<select id="printLayers" data-dojo-type="dijit/form/MultiSelect" name="layers"></select>
</td>
</tr>
</tbody>
</table>
<div>
<button data-dojo-type="dijit/form/Button" type="submit">OK</button>
</div>
</div>
然后我将模板作为文本加载到我的小部件中define([...,...,...,"dojo/text!./PrintWidget/templates/DialogContent.html"]...)
这是作为字符串变量出现的,但我需要#printLayers
动态添加选项。因为它只是一个文本字符串,所以我不能将它用作 dom 节点。当我使用domConstruct.toDom(dialogContent)
它时,它会转换为我可以使用的实际 dom 节点,但由于此时 dom 节点实际上尚未添加到 DOM(它只是一个 javascript dom 对象),我无法#printLayers
通过dom.byId
or访问dojo/query
。
如何#printLayers
在我的模板中访问以动态添加option
元素?