关于EditText有误。参考http://blog.csdn.net/mwj_88/article/details/44117901
或许你知道listview的item是checkbox应该怎么处理。但是你试过listview的item是edittext吗?复习下checkbox处理逻辑:
1、在适配器中定义一个list<Object>保存checkbox的状态,构造函数中初始化
2、在适配器的getView()中给checkbox重新赋值
3、在checkbox的点击事件中更改checkbox的状态
而当包含EditText时,处理逻辑:
1、在适配器中定义一个list<Object>保存checkbox的状态,构造函数中初始化
2、在EditText.addTextChangedListener()中保存值
3、每当在EdiTText上输入时,getView()会重新被调用(从0到list.size执行一遍);且由于在第一个EditText上输入时,所有EdiTText的addTextChangedListener()都会被调用。所以需要特别处理下position==0的情况,看代码:
private int b;
<span style="white-space:pre"> </span>@Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView==null) {
holder=new ViewHolder();
convertView=LayoutInflater.from(context).inflate(R.layout.addcomitem, null);
holder.price=(EditText) convertView.findViewById(R.id.price);
convertView.setTag(holder);
}else {
holder = (ViewHolder) convertView.getTag();
}
holder.price.setHint("请输入"+addComlist.get(position).getItemName()+"的价格");
System.out.println("=========="+position);
b=0;
holder.price.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
b++;
if(b<=1){
list.set(position, s.toString());
System.out.println(position+"--------"+s.toString());
}
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
}
@Override
public void afterTextChanged(Editable s) {
}
});
return convertView;
}