当前位置:首页 > javascript > 正文内容

IOS软键盘收起留白问题及Input光标过长问题

tigon5年前 (2020-07-31)javascript3025

1.Input光标过长问题
iso 中input 光标长度与line-height有关,input本身字体就是上下居中的因此不需要设置,但如果想控制光标的长度可以通过设置line-height高度来控制;

2.IOS软键盘收起留白

1.可以通过输入框失去焦点

<div class="input flex1 aic flex pl20 pr20">
    <input v-model="msgContent" type="text" placeholder="说点什么吧" @blur="onBlur">
 </div>
 //输入框失焦后回到页面首部 IOS12,微信6.7.4有这个问题
      onBlur () {
        if (isBrower('iphone')) {
          window.scrollTo(0,0)
        }
        window.scrollTo(0,0)
      }

如果来多个输入框则会出新下去上来反复的问题

通过监听窗口大小的变化来实现

window.addEventListener('resize', function() {
  if (document.activeElement.tagName === 'INPUT' || document.activeElement.tagName === 'TEXTAREA') {
    window.setTimeout(function() {
      if ('scrollIntoView' in document.activeElement) {
        document.activeElement.scrollIntoView(false)
      } else {
        document.activeElement.scrollIntoViewIfNeeded(false)
      }
    }, 0)
  }
})

这个方法在微信里面不支持,监听不到;

3.通过全局监听失去焦点 ,并使用变量延迟进行处理

var flage = false
window.addEventListener('focusin', function() {
  flage = false
})
window.addEventListener('focusout', function() {
  flage = true
  setTimeout(function(){
    if(flage){
      window.scrollTo(0, 0)
    }
  })
})

版权声明:本文由Web学习之路发布,如需转载请注明出处。

本文链接:https://www.webge.net/?id=92

“IOS软键盘收起留白问题及Input光标过长问题” 的相关文章

event-loop

event-loop

如果知道js运行机制,在工作中会帮助我们更好的理解和编写代码,也知道为什么js是单线程js为什么是单线程原因,就是为了避免DOM渲染的冲突异步是一种“无奈”的解决方案,虽然有很多问题,如下:1,没按照书写方式执行,可读性差2,callback中不容易模块化什么是event-loop1,同步代码,直接...

数组去重

var a=[1,3,4,5,6,1,3,9,6]; //代码是去重后的 function arrfn(data){ let newObj={}; for(let i=0;i<data.length;i++...

最全的js运行机制

最全的js运行机制

主线程Event Queue:(微任务,宏任务) 1,主线程执行完后2,到Event Queue里找,先执行微任务,再宏任务...

js 判断数组,对象

arr=[1,2,3,4]; obj={a:'aaa'}; console.log(arr.constructor===Object) //false arr instanceof Array //true Object.prototype.toString.call(...

防抖和节流

如果我在一个时间内只执行一次,最好用防抖,如果只是想在执行时,设置一下间隔时间那么用节流 防抖是在一个时间内只能执行一次,如果频繁操作就会清除重新开始计算执行,我设置的时间内整个过程中只会执行一次/* 函数的防抖 debounce,不是某个事件触发就去执行函数,而是在指定的时间间隔内执行...