var openSoftKeyboard = function() { if(mui.os.ios) { var webView = plus.webview.currentWebview().nativeInstanceObject(); webView.plusCallMethod({ "setKeyboardDisplayRequiresUserAction": false }); } else { var webview = plus.android.currentWebview(); plus.android.importClass(webview); webview.requestFocus(); var Context = plus.android.importClass("android.content.Context"); var InputMethodManager = plus.android.importClass("android.view.inputmethod.InputMethodManager"); var main = plus.android.runtimeMainActivity(); var imm = main.getSystemService(Context.INPUT_METHOD_SERVICE); imm.toggleSoftInput(0, InputMethodManager.SHOW_FORCED); } } 1. mui.plusReady(function() { //页面隐藏事件 plus.webview.currentWebview().addEventListener("hide",function(e){ document.getElementById("search").value=""; document.getElementById("search").blur();//搜索框取消焦点,关闭软键盘 }); //页面显示事件 plus.webview.currentWebview().addEventListener("show",function(e){ setTimeout(function() {//自动打开软键盘,搜索框获取焦点 openSoftKeyboard(); document.getElementById("search").focus(); }, 600); return false; }); })
注意的bug: ajax 调用 、 createview 的创建 或者 销毁、plus.nativeUI 的 showWaiting() closeWaiting() 等等,会引起当前页面的聚焦问题,所以会导致blur()的触发,而blur()会自动调用native 的 软键盘关闭。
综上所述,由于各种原因导致失去焦点,引起软键盘闪退。
focus() 聚焦引起的软键盘闪退问题: 做适当的延迟就行了
setTimeout(function() {
mobile.focus();
}, 300)
软键盘的数字选项:(默认英文选项)
<input id="search" type="tel"/>