用Angular5.2.9 + Ionic3.2 + Ionic Native 4.5.3 + Cordova8.0 + Cordova-ios 4.5.4 + Cordova-plugin-inappbrowser 2.0.3-dev 做了一個帶有InAppBrowser的APP,在APP中訪問如下html,運行后效果 以及 代碼如下:
testsoftkeyboard3.html
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Pragma" content="no-cache">
<meta http-equiv="Cache-Control" content="no-cache">
<meta http-equiv="Expires" content="0">
<script src="http://libs.baidu.com/jquery/1.9.1/jquery.min.js"></script>
<script language="javascript">
var objInput1=null;
var objInput2=null;
function initLoad()
{
objInput1=document.getElementById("input1");
objInput2=document.getElementById("input2");
}
function onBlur(event)
{
if(event.target.value == 'abc')
{
event.target.style.backgroundColor="#ffffff";
return true;
}
//這里如果不用setTimeout來執(zhí)行alert,那么當采用下面描述的方式2時,整個InAppBrowser會死掉,不想應任何操作
setTimeout(function () {
alert('please input abc');
//objInput1.focus();
//objInput1.click();
}, 0);
event.target.style.backgroundColor = "#ff0000";
event.target.focus();
event.target.click();
return false;
}
</script>
</head>
<body onload="javascript:initLoad()">
input1:<input type="text" id="input1" onblur="javascript:onBlur(event);"/>     -     
input2:<input type="text" id="input2"/>
<br/>
</body>
</html>
上面的代碼主要是為了實現以下效果:
第1步、當焦點在input1中時,iPad自動顯示軟鍵盤(代碼上沒有特意控制,應該是iOS 默認的功能,焦點在輸入框時會自動彈出軟鍵盤)
第2步、當在input1中輸入內容后,在失去焦點時進行輸入檢查(在onblur事件中實現),如果發(fā)現輸入的內容不為abc,則彈出alert警告
第3步、同時將input1的背景色改為紅色,并且讓焦點回到input1,并自動顯示出軟鍵盤
目前遇到的問題主要出在上面第2步與第3步,讓input1失去焦點有兩種方式:
方式1、點擊input2
方式2、按軟鍵盤最右下角的按鈕將鍵盤收起
目前按方式1來操作,沒有問題,第3步能按照預期的效果呈現。
但是當采用方式2時,當通過調用focus()方法讓input1獲得焦點后,軟鍵盤會閃現(出現后,又馬上消失),試了很多方法都能保持軟鍵盤一直出現,調查了2,3天都沒搞定,不知道是否需要修改InAppBrowser的Objective-C代碼,麻煩大家?guī)兔匆幌聭撛鯓咏鉀Q?非常感謝!
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數據專業(yè)的國家
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產業(yè)為響應國家深化產教融合/校企合作的政策,積極推進“中國制造2025”,實現中華民族偉大復興的升級產業(yè)鏈。利用北京大學優(yōu)質教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經理從事移動互聯網管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經理職務負責iOS教學及管理工作。
浪潮集團項目經理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網頁制作和網頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經驗。曾經歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。