我们使用带有Type Ahead的inputText XPages控件进行自动完成。在搜索字段中输入内容时,不会显示任何建议。我们在“预输入类型”属性窗格中设置了以逗号分隔的建议列表,建议分隔符为“,”。我们也尝试过使用“新线”分离的建议。最小字符为“1”。这是inputText的xml:
<xp:inputText id="inputText2">
<xp:typeAhead mode="partial" minChars="1" ignoreCase="true" valueListSeparator=",">
<xp:this.valueList><![CDATA[Homer,Marge,Bart,Lisa,Maggie]]></xp:this.valueList>
</xp:typeAhead>
</xp:inputText>
使用模式“full”和“partial”都会失败,但会出现不同的错误。当使用“full”时,对于在搜索字段中键入的每个字母,浏览器控制台中会出现以下错误(是的,所有这些都是由单键按下引起的):
Error: Unable to load undefined status:404
dijit.form.ComboBox: Error: Unable to load undefined status:404
Error: Unable to load undefined status:404
Error: Unable to load undefined status:404
Error: Unable to load undefined status:404
对于模式“partial”,类似的每个字母都会显示以下错误消息:
'url' is null or not an object
此最后一个错误源自dojo.js(与Lotus Notes 8.5.3一起使用的缩小版本,第14行,字符84996)。我们不确定这是哪个版本的dojo,因为它没有在缩小的脚本中说明,但我们认为Version 1.6.1大致是正确的版本。我们已经隔离了导致错误的代码:
dojo._ioAddQueryToUrl = function(/*dojo.__IoCallbackArgs*/ioArgs){
//summary: Adds query params discovered by the io deferred construction to the URL.
//Only use this for operations which are fundamentally GET-type operations.
if(ioArgs.query.length){
ioArgs.url += (ioArgs.url.indexOf("?") == -1 ? "?" : "&") + ioArgs.query;
ioArgs.query = null;
}
};
导致错误的是ioArgs.url += ...
。
生成的inputText标记如下所示:
<span id="view:_id36:_id38:_id119" dojotype="ibm.xsp.widget.layout.data.TypeAheadReadStore" jsid="view__id36__id38__id119" mode="full"></span>
<div class="dijit dijitReset dijitInlineTable dijitLeft xspInputFieldEditBox dijitTextBox dijitComboBox" id="widget_view:_id36:_id38:inputText2" role="combobox" widgetid="view:_id36:_id38:inputText2">
<div class="dijitReset dijitRight dijitButtonNode dijitArrowButton dijitDownArrowButton dijitArrowButtonContainer" dojoattachpoint="_buttonNode, _popupStateNode" role="presentation" style="display: none;">
<input class="dijitReset dijitInputField dijitArrowButtonInner" value="? " type="text" tabindex="-1" readonly="readonly" role="presentation">
</div>
<div class="dijitReset dijitValidationContainer">
<input class="dijitReset dijitInputField dijitValidationIcon dijitValidationInner" value="? " type="text" tabindex="-1" readonly="readonly" role="presentation">
</div>
<div class="dijitReset dijitInputField dijitInputContainer">
<input class="dijitReset dijitInputInner" name="view:_id36:_id38:inputText2" type="text" autocomplete="off" dojoattachpoint="textbox,focusNode" role="textbox" aria-haspopup="true" id="view:_id36:_id38:inputText2" tabindex="0" value="">
</div>
</div>
任何建议(双关语)都将不胜感激!
答案 0 :(得分:4)
请检查XPages属性 createForm 。如果设置为 false ,请将其删除或将其更改为 true 。
<xp:view xmlns:xp="http://www.ibm.com/xsp/core" createForm="true">
Type Ahead功能从HTML表单的 action 属性计算目标URL。如果此表单不可用,则前面的类型将失败。 如果需要禁用自动生成的表单,则必须手动将表单添加到XPage。
修改强>
另外,您可以覆盖Typeahead数据存储的CSJS代码并操纵 fetch 方法来注入XPage的URL。
编辑2:
这是一个修复typeahead的脚本块:
<xp:scriptBlock id="scriptBlockFixTypeAhead">
<xp:this.value>
<![CDATA[dojo.addOnLoad(function(){
ibm.xsp.widget.layout.data.TypeAheadReadStore.prototype.fetch = function tars_f(_5) {
var _6 = _5.query.name;
if (_6.length < this.minChars) {
_5.onComplete([], _5);
return;
}
this.content.$$value = _6;
var _7 = {url: '#{javascript:context.getUrl().getPath()}',
handleAs: "text", timeout: XSP.submitLatency, content: this.content,
form: this.sendForm ? this.formId : null,
load: dojo.hitch(this, this.retrieved, _5),
error: dojo.hitch(_5, _5.onError)};
dojo.xhr(this.method, _7, !this.contentInUrl);
return _5;
}})
]]></xp:this.value>
</xp:scriptBlock>