uniapp 自动获取焦点,不弹出软键盘

文章讲述了在开发过程中遇到的app进入页面后自动弹出软键盘问题,介绍了两种解决方案:一是通过定时操作隐藏键盘,但可能带来闪现效果;二是使用`v-model`和`focus`事件管理焦点,提供更流畅的用户体验。
摘要由CSDN通过智能技术生成

最近做项目遇见这样一个问题,app进入某一个页面后自动弹出软键盘,查找原因后发现是因为input使用了auto-focus自动获取焦点所致。解决办法如下:

第一种:

onLoad(option) {
            
    //解决app进入页面弹出软键盘
    let _self = this
    _self.keyStop()
},
methods: {
    //禁止软件盘自动弹出
    keyStop(){
    var interval = setInterval(function(){
            uni.hideKeyboard();//隐藏软键盘
            console.log('刷新')
        },20);
        setTimeout(() => {
            clearInterval(interval);
            console.log('停止刷新')
        },3000);
    },
}

这一种方法会有闪现情况发生,体验感不是很好。

第二种方法:

<input type="text" class="inp-t" v-model="formData.transcendentalist"  :focus="isFocus" @tap="getFocus" />

data(){
    return{
        isFocus:false 
    }
},
methods{
    getFocus(){
        this.isFocus = true    
    }
}

这一种方法相对要比第一种好很多。

希望上面两种方法可以解决大家的问题。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
EditText默认获取焦点弹出软键盘,在Android开发中非常常见和实用。当我们在布局文件中使用EditText控件时,默认情况下,该控件会自动获取焦点弹出软键盘。 这种默认行为可以方便用户直接对EditText进行输入操作,提高用户的交互体验。当用户点击EditText或切换到包含EditText的布局时,EditText会自动获得焦点,这样用户可以直接进行输入操作。 在代码中,我们可以通过设置android:focusable属性为true来保证EditText默认获取焦点。同时,还可以设置android:focusableInTouchMode属性为true,确保用户触摸到屏幕上的EditText时,它会获取焦点弹出软键盘。 例如,在布局文件中可以这样设置: <EditText android:id="@+id/editText" android:layout_width="match_parent" android:layout_height="wrap_content" android:focusable="true" android:focusableInTouchMode="true" /> 这样,当布局加载完成后,EditText会自动获取焦点,用户可以直接对其进行输入操作。 需要注意的是,如果你希望EditText不再获取焦点弹出软键盘,则可以将android:focusable和android:focusableInTouchMode属性设置为false。 尽管EditText默认获取焦点弹出软键盘在很多情况下非常方便,但有些场景可能不适用,比如登录界面中的密码框,我们可能更愿意让用户手动点击密码框来输入密码,而不是自动弹出软键盘。 总之,EditText默认获取焦点弹出软键盘是一个很方便的功能,可以提高用户的交互体验,但在一些特殊场景中需要谨慎使用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值