即使在添加观察者之前设置了文本,TextWatcher也会调用

时间:2011-03-01 06:07:42

标签: android textwatcher

在Android活动中,我首先恢复EditText中的文本,然后向其中添加TextWatcher。

private static int WC = 0;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.e("TextWatcherTest", "onCreate:\t" +CLASS_NAME);
setContentView(R.layout.main);

EditText et = (EditText)findViewById(R.id.editText);
Log.e("TextWatcherTest", "Set text xyz");
et.setText("xyz");

et.addTextChangedListener(new TextWatcher() {
    @Override
    public void onTextChanged(CharSequence s, int start, int before, int count) { }
    @Override
    public void beforeTextChanged(CharSequence s, int start, int count, int after) { }
    @Override
    public void afterTextChanged(Editable s) {
        Log.e("TextWatcherTest", "afterTextChanged:\t" +s.toString());
    }
});
}

但是当我运行活动时,即使在设置文本后添加了Watcher本身,也会调用afterTextChanged方法。所以日志输出类似于

onCreate:    LifecycleMain
Set text xyz
// screen rotation
onCreate:    LifecycleMain
Set text xyz
afterTextChanged:    xyz    2

TextWatcher中的计数器显示被调用的观察者是在EditText中设置文本后添加的观察者。任何想法为什么会发生这种情况以及如何防止这种情况发生?

2 个答案:

答案 0 :(得分:8)

解决方法是将addTextChangedListener移动到onPostCreate方法。一切都将得到解决。

答案 1 :(得分:1)

这绝对必须发生。当savedinstanceState不为null时(意味着保存了先前的对象状态),您正在设置文本。

我认为这是因为您在onCreate方法中将TextWatcher添加到EditText中,并且下次onCreate被调用(例如,在配置更改后),然后它发现TextWatcher已经添加到EditText。

如果您想检查这种情况,请将其放在您的条件之前:

if(savedInstanceState == null){
    Log.e("savedInstance state is null", "no text");
    et.setText("No text");
}

在这种情况下,如果在EditText上调用setText,则不会调用afterTextChanged(Editable s)。