我们在使用SearchView的时候,总会用到监控文本框变化的事件,代码如下:
//文本框输入事件
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
//输入完成后,点击回车或是完成键
@Override
public boolean onQueryTextSubmit(String query) {
if (query.length() > 0) {
Log.e("onQueryTextSubmit","我是点击回车按钮");
}
return true;
}
//查询文本框有变化时事件
@Override
public boolean onQueryTextChange(String newText) {
Log.e("onQueryTextChange","我是内容改变");
return false;
}
});
当我们按回车的时候,你会发现,打印了两条,这是为什么呢,上网查了一下发现,原来是search键,在按下和松开时,分别运行了,action_down和 action_up两个方法,这两方法又都运行了这个查询事件,这怎么办呢,我们知道,如果查询框为空的话,它不会运行,所以我们在运行我们的代码之后加上
//添加下面一句,防止数据两次加载
searchView.setIconified(true);
就OK了.
//文本框输入事件
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
//输入完成后,点击回车或是完成键
@Override
public boolean onQueryTextSubmit(String query) {
if (query.length() > 0) {
Log.e("onQueryTextSubmit","我是点击回车按钮");
searchView.setIconified(true);
}
return true;
}
//查询文本框有变化时事件
@Override
public boolean onQueryTextChange(String newText) {
Log.e("onQueryTextChange","我是内容改变");
return false;
}
});