zoukankan      html  css  js  c++  java
  • EditText: EditText自动获取焦点并弹出键盘&EditText不自动获取焦点并且不会弹出键盘

    1.EditText不自动获取焦点并且不会弹出键盘

    找到EditText的父控件,设置其父控件为:

    Parent.setFocusable(true);
    Parent.setFocusableInTouchMode(true);

    2. 调用指定方法令 EditText自动获取焦点并弹出键盘

    private void showInputTips(EditText et_text) {
            et_text.setFocusable(true);
            et_text.setFocusableInTouchMode(true);
            et_text.requestFocus();
            InputMethodManager inputManager =
                    (InputMethodManager) et_text.getContext().getSystemService(Context.INPUT_METHOD_SERVICE);
            inputManager.showSoftInput(et_text, 0);
        }

    3.点击进入Activity后就让 EditText自动获取焦点并弹出键盘

    et_text = (EditText) findViewById(R.id.et_text);
            et_text.setFocusable(true);
            et_text.setFocusableInTouchMode(true);
            et_text.requestFocus();

    并在清单文件中设置该Activity的属性: android:windowSoftInputMode="stateVisible" 

    Q: 为什么给EditText的父布局设置focusableInTouchMode = true,就能够阻止EditText自动获取焦点?
    A:我们都知道如果在布局中有EdiText的话,EditText会默认获得焦点,弹出键盘。事实上,对于手机来说,只需要添加  android:focusableInTouchMode = true  就可以了。
    EditText自动获取焦点主要是因为当我们没有给EditText的父布局设置focusableInTouchMode的时候,它的父布局是默认没有这个能力的,所以焦点就会直接被EditText争夺去。如果我们设置了focusableInTouchMode的话,这样EditText的父布局就会有这个能力了,这样只有我们触摸的时候触发相应的事件,通过Android中的事件传递机制进行传递了。

  • 相关阅读:
    react native配置ip真机测试
    APP Store上架QA&注意事项
    iOS 开发】解决使用 CocoaPods 执行 pod install 时出现
    iphoneX适配!!!
    better-scroll和swiper使用中的坑
    js知识巩固
    vue的学习(常用功能)
    vue学习生命周期(created和mounted区别)
    jq常用功能操作
    移动端中遇到的坑(bug)!!!
  • 原文地址:https://www.cnblogs.com/yongdaimi/p/10606262.html
Copyright © 2011-2022 走看看