关于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; }