Js控制iphone端的input/textarea元素失去焦点时隐藏键盘
原文http://www.it165.net/pro/html/201404/12672.html
IPHONE系统在点击document时textarea和input没有失去焦点
function objBlur(obj, time){ if(typeof obj != 'string') return false; var obj = document.getElementById(obj), time = time || 300, docTouchend = function(event){ if(event.target!= obj){ setTimeout(function(){ obj.blur(); document.removeEventListener('touchend', docTouchend,false); },time); } }; if(obj){ obj.addEventListener('focus', function(){ //注释这部分是在一个页面多个这样的调用时禁止冒泡让他不要让ios默认输入框上下弹,最好写在对应页面里给对应元素写这里效率低,这种写法很差所以先注释掉下次优化再贴 // var input = document.getElementsByTagName('input'), // ilength = input.length; // for(var i=0; i<ilength; i++){ // input[i].addEventListener('touchend',function(e){e.stopPropagation()},false); // } // var textarea = document.getElementsByTagName('textarea'), // tlength = textarea.length; // for(var i=0; i<tlength; i++){ // textarea[i].addEventListener('touchend',function(e){e.stopPropagation()},false); // } document.addEventListener('touchend', docTouchend,false); },false); }else{ //找不到obj } }
调用方法如下 var isIPHONE = navigator.userAgent.toUpperCase().indexOf('IPHONE')!= -1; if(isIPHONE){ var input = o.objBlur, input2 = new input('realName'), input3 = new input('telphone'), input4 = new input('address'), input2 = input3 = input4 = null; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下