1

我正在使用 Spring Roo 创建一个页面,该页面进行 ajax 调用并使用来自 Ajax 调用的搜索表单填充页面的一部分。这一切都是通过使用标准 Roo 标记和 Javascript 库来完成的。Ajax 返回的表单很简单,只有一个选择列表。

<jsp:root xmlns:c="http://java.sun.com/jsp/jstl/core"
xmlns:fn="http://java.sun.com/jsp/jstl/functions"
xmlns:field="urn:jsptagdir:/WEB-INF/tags/form/fields"
xmlns:form="urn:jsptagdir:/WEB-INF/tags/form"
xmlns:springform="http://www.springframework.org/tags/form" 
xmlns:jsp="http://java.sun.com/JSP/Page"
xmlns:spring="http://www.springframework.org/tags" version="2.0">
<div>
    <jsp:directive.page contentType="text/html;charset=UTF-8" />
    <jsp:output omit-xml-declaration="yes" />
    <form:search
        id="fc_domain_profile_combination"
        modelAttribute="combination" path="/profiles/search/combinations"
        z="e2lXrqKKD2CS7Zjefas2ZXPW4xYNM=">
        <field:select field="searchProcessingCenter" renderempty="true" disabled="true"
                id="c_profile_combofilter_processingcenter"
                items="${proccenters}" path="/profiles"
                itemLabel="name" itemValue="id"/>
    </form:search>
    <input type="hidden" id="blockSubmitHd" value="false" />
</div>

此代码在 Firefox 和 Google Chrome 中运行良好,但在 IE 中失败并出现“未知错误”。问题发生在 Roo 中包含的 Ajax 方法中:

function callXhrGet(contentId, ajaxUrl){
  var _targetNode = dojo.byId(contentId);
  var xhrArgs = {
      url: ajaxUrl,
      preventCache: true,
      handleAs:"text",
      load: function(data) {
        dojo.html.set(_targetNode,data,{parseContent:true});
        dojo.forEach(dojo.query("script", _targetNode),function(node){
            dojo.eval(node.innerHTML);
        });
        dojo.parser.parse(_targetNode);
      },
      error: function(error) {
          _targetNode.innerHTML = "An unexpected error occurred: " + error;
      }
  };
  dojo.xhrGet(xhrArgs);

}

尝试处理以下dojo.eval(node.innerHTML);行时失败:

Spring.addDecoration(new Spring.ElementDecoration({elementId : '_searchProcessingCenter_id', widgetType: 'dijit.form.FilteringSelect', widgetAttrs : {hasDownArrow : true, required : false, invalidMessage: 'Please enter valid Role Type' }}));

有趣的是,当列表为空时它工作正常,其他dijit.form.tags工作也很好。任何建议和反馈如何解决这个问题?

4

0 回答 0