这个标题非常绕口,只是这也是想了半天的成果,对不起体育老师了。
标题想表达的是:之前讲过的用combobox实现自己主动提示组件。只是如今规定该组件不能够保存data中不存在的数据。
最初的想法是通过onChange事件来作推断。可是无奈该函数在自己主动提示的模式下,每change一次会触发2次onChange事件,太诡异了遂放弃之。
并且onChange事件是在每次combobox中的内容改变时触发,若是keyword输入过程中,该事件一直触发。
而我们所要的效果是等用户输入结果再作校验,所以不符合要求。
查找API发现combo提供了一个onHidePanel事件的扩展点,当自己主动提示框隐藏时触发。
当时的想法是:输入完之后当然会隐藏输入框啦,感觉能够当成是完毕输入的标识。
试了试,基本能够满足要求。有点小问题。就是用户高速输入之后点击其它地方。combobox失去焦点之后,有可能连输入框都不显示,何谈隐藏?
哎~通过现有API好像都无法完美地解决这个问题,那么就仅仅有自己写了。。but 我的前端水平真是不怎么样,瞎j8鼓捣了一个版本号,大家凑合看看~
$.extend($.fn.combobox.methods, { completeCheck:function(jq){ var textbox = jq.combobox('textbox'); console.log(jq) textbox.on('blur', function(){ setTimeout('doCompleteCheck("' + jq.selector + '")', 200); // 这里先让combobox的一些操作走 }) } }); function doCompleteCheck(selector){ var jq = $(selector); var value = jq.combobox('getValue'); var json = jq.combobox('getData'); if(!findInJson(json, value)){ jq.combobox('clear'); jq.combobox('hidePanel'); } }
我为combobox加入了一个新的方法:completeCheck
主要是为combobox中的textbox加入一个onBlur事件,这个textbox也就是我们在输入时的那个input组件。
那么当textbox失去焦点时则会触发doCompleteCheck函数。可是这里先要让combobox的一些操作先运行
所以我们给了200ms的延迟,之后通过比較是否存在在data中来决定是否须要清空combobox中的输入值
这里补充一点,事实上若是输入的内容不在data中。combobox('getValue')的值都会是undefined,所以这样也能够来推断。
使用的时候就像调用combobox的其它方法一样就能够了。$('#cc').combobox('completeCheck');