当我使用发布表单时dojo.xhrPost
,我得到了表单中的所有字段,除了 dojox.Checked MultiSelect 的值,无论选择什么选项。
我的 CheckedMultiSelect 的声明:
<div dojoType="dojo.data.ItemFileReadStore" jsId="processTypeList" url="json/processtypelist.json.php"></div>
<label for="processTypeSelect">Process Types</label>
<select dojoType="dojox.form.CheckedMultiSelect" name="processTypeSelect" id="processTypeSelect" multiple="true" style="height:166px;" store="processTypeList"></select>
这是我的 xhrPost:
<button dojoType="dojox.form.BusyButton" id="logSearchSubmit" busyLabel="Searching..." timeout="5"
onclick="dojo.xhrPost({
url: 'handlers/logsearch.php',
form: dojo.byId('formSearch'),
handleAs: 'json'
});">Search</button>
这是我发布的内容:
endDate 2009-12-15
postAction search
processSelect
searchAttribute none
searchAttributeValue
startDate 2009-12-15
尽管属于我的表单的 dijit 控件的所有值都已发布,但 dojox 控件值未发布的原因是什么?该控件位于值被发布的其他控件之间,所以我知道它在表单内。
我刚刚添加了另一个按钮来执行console.log(formSearch.getValues())
而不是 xhrPost ,我得到了登录到控制台的控件的值。很明显道场意识到了这一点,但是当我做一个console.log(dojo.formToJson("formSearch"))
我再次获得了除 dojox 控件之外的所有表单数据。
我猜测这是 CheckedMultiSelect 中的一个错误,它不会将声明的标记中的“名称”属性传递到将在表单提交中使用的隐藏选择小部件。由于某些 IE 行为,dijit.form 小部件必须以相当笨拙的方式执行此操作,插入${nameAttrSetting}
直接进入模板 (CheckedMultiSelect.html) 的 select 元素。有关示例,请参阅 dijit/form/templates/Button.html。
CheckedMultiSelect 继承自 dijit,但需要在其自己的模板中复制此修复,因为它无法继承。如果这是解决方案,请考虑向 bugs.dojotoolkit.org 提交报告和补丁。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)