程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决在 jetpack Compose 中关闭键盘时如何清除 TextField 焦点??

开发过程中遇到在 jetpack Compose 中关闭键盘时如何清除 TextField 焦点?的问题如何解决?下面主要结合日常开发的经验,给出你关于在 jetpack Compose 中关闭键盘时如何清除 TextField 焦点?的解决方法建议,希望对你解决在 jetpack Compose 中关闭键盘时如何清除 TextField 焦点?有所启发或帮助;

我正在使用 OutlinedTextFIEld。

当我开始编辑时,后退按钮变成隐藏键盘按钮(向下箭头)。

第一次按下后退按钮会隐藏键盘,但焦点仍在文本字段上。未调用 onFocusChangedBACkPressHandler 处理程序。

第二次按下后退按钮清除焦点:onFocusChanged 被调用,而 BACkPressHandler 不是。

BACkPressHandler {
    println("BACkPressHandler")
}
val valueState = remember { mutableStateOf(TextFIEldValue(text = "")) }
OutlinedTextFIEld(
    value = valueState.value,onValueChange = {
        valueState.value = it
    },modifIEr = ModifIEr
        .fillMaxWIDth()
        .onFocusChanged {
            println("isFocused ${it.isFocuseD}")
        }
)

第三次 BACkHandler 工作正常,我从 compose-samples 获取 if。只是用于测试,我不应该在这里需要它,它预计在第一次点击后退按钮后焦点会丢失

解决方法

带有焦点文本字段的 compose issue 可防止后退按钮在键盘隐藏时关闭应用程序。它被标记为已修复,但将包含在未来的某个版本中,而不是包含在 1.0

但是,据我了解,在键盘被解除后文本字段没有失去焦点的事实是 Android 上的预期行为(因为可能连接了键盘?我没有得到原因)。这也是它在旧的 android 布局中的工作方式

这对我来说似乎很奇怪,所以我提供了以下修饰符,它在键盘消失时退出焦点:

fun Modifier.fixKeyboardFocusIssue(): Modifier = composed {
    var isFocused by remember { mutableStateOf(false) }
    val scope = rememberCoroutInescope()
    if (isFocused) {
        // TODO: replace with single if when https://issuetracker.google.com/issues/193907134 fixed
        if (!LocalWindowInsets.current.ime.isVisiblE) {
            LocalFocusmanager.current.clearFocus()
        }
    }
    onFocusChanged {
        if (it.isFocused && !isFocused) {
            scope.launch {
                // wait until keyboard presented on start ediTing
                delay(300)
                isFocused = it.isFocused
            }
        } else {
            isFocused = it.isFocused
        }
    }
}

用法:

BasicTextField(
    value = valueState.value,onValueChange = {
        valueState.value = it
    },modifier = Modifier
        .fixKeyboardFocusIssue()
)

大佬总结

以上是大佬教程为你收集整理的在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?全部内容,希望文章能够帮你解决在 Jetpack Compose 中关闭键盘时如何清除 TextField 焦点?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。