input在移动端不容易获取焦点问题及获取焦点后Android手机键盘弹起覆盖输入框问题解决

给input包裹一层父级div 并添加点击事件使input获取焦点
html代码

<div class="inputBox" @click="inputClicked('activeInput')"><input v-model="activeChecked" @focus="androidFocus" ref='activeInput' /></div>

js方法:

androidFocus(){
    
    
	//此处获取本地存储UA为通过 navigator.userAgent 获取的判断终端的机型 具体方法不再阐述
	var UA = localStorage.getItem("UA");
	console.log("UA", UA);
	if (UA == "Android") {
    
    
	  console.log("安卓方法");
	  //获取焦点后Android手机键盘弹起覆盖输入框问题解决
	  document.body.scrollTop = document.body.scrollHeight;
	} else {
    
    
	  console.log("苹果方法");
	}
},
//增大input获取焦点点击区域方法
inputClicked(inputName){
    
    
	if (this.$refs[inputName]) {
    
    		
	    this.$refs[inputName].focus(()=>{
    
    
	    	//获取焦点后Android手机键盘弹起覆盖输入框问题解决
			document.body.scrollTop = document.body.scrollHeight;
		});
	}
},

猜你喜欢

转载自blog.csdn.net/qq_40969782/article/details/111621523
今日推荐