ListView集合中设置标记 setTag();方法带一个参数和两个参数的区别,以及设置标记时ViewHolder中的每一个属性控件都需要设置一次,否则在Item中每一个控件的点击事件中取出设置的标

ListView集合中设置标记 setTag();方法带一个参数和两个参数的区别;以及设置标记时ViewHolder中的每一个属性控件都需要设置一次,否则在Item每一个控件的点击事件中取出设置的标标记时会报空指针异常。

1、setTag(Object  tag); 带一个参数的方法,相信大家都明白,没什么好讲的,设置时对应ViewHolder的每一个控件一一设置就可以了;

         2、setTag(int key,Object tag);带两个参数的方法,第一个参数键值,是唯一的,不能任意的写一个int 类型的数,它的值必须在 Values ——>strings.xml文件中进行定义,定              义格式如下:

    <!--GroupListFragment为setTag添加键值-->
    <item type="id" name="tag_first"></item>
    <item type="id" name="tag_btnRemove"></item>
    <item type="id" name="tag_customSwitch"/>
         然后在设置标记时就可以如下使用了:

   holder.btnRemove.setTag(R.id.tag_btnRemove,i); 

 在取出设置的标记时根据键值取出如下:
   
   view.getTag(R.id.tag_btnRemove);    设置的时候ViewHolder中的每一个属性都要一一设置,否则取出设置的标记时会报空指针异常;这两个天坑都耽误了我好长的时间:一个是没有对ViewHolder中的每一个属性一一设置标签,只是用其中的某一个属性进行设置,结果空指针就出来啦,第二个是在使用带两个参数的setTag方式时,键值就随便的弄了一个整数,结果也报了一大堆的错误。                     真心的希望你们遇到此类问题时能有所帮助,不要在浪费那么的时间了。

      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这里是一个简单的示例代码,用于演示如何使用SearchViewListView实现搜索功能,并在ListView点击其一项跳转到其页面。 首先,我们需要在布局文件定义一个SearchView一个ListView,如下所示: ``` <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <SearchView android:id="@+id/searchView" android:layout_width="match_parent" android:layout_height="wrap_content" /> <ListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> ``` 接下来,我们需要在Activity实现SearchView的监听器,并在onQueryTextSubmit方法执行搜索逻辑。在这个示例代码,我们将搜索结果保存在一个ArrayList,并使用一个自定义的Adapter来显示ListView的数据。 ``` public class MainActivity extends AppCompatActivity implements SearchView.OnQueryTextListener { private ListView listView; private SearchView searchView; private MyAdapter adapter; private ArrayList<Item> itemList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView = findViewById(R.id.listView); searchView = findViewById(R.id.searchView); itemList = new ArrayList<>(); itemList.add(new Item("Apple", "https://www.apple.com")); itemList.add(new Item("Google", "https://www.google.com")); itemList.add(new Item("Microsoft", "https://www.microsoft.com")); itemList.add(new Item("Facebook", "https://www.facebook.com")); adapter = new MyAdapter(this, itemList); listView.setAdapter(adapter); searchView.setOnQueryTextListener(this); } @Override public boolean onQueryTextSubmit(String query) { ArrayList<Item> tempList = new ArrayList<>(); for (Item item : itemList) { if (item.getName().toLowerCase().contains(query.toLowerCase())) { tempList.add(item); } } adapter.setData(tempList); return false; } @Override public boolean onQueryTextChange(String newText) { return false; } } ``` 接下来,我们需要实现一个自定义的Adapter来显示ListView的数据,并在其实现ListView点击事件,以便在用户点击其一项跳转到其页面。 ``` public class MyAdapter extends BaseAdapter { private Context context; private ArrayList<Item> itemList; public MyAdapter(Context context, ArrayList<Item> itemList) { this.context = context; this.itemList = itemList; } public void setData(ArrayList<Item> itemList) { this.itemList = itemList; notifyDataSetChanged(); } @Override public int getCount() { return itemList.size(); } @Override public Object getItem(int position) { return itemList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = LayoutInflater.from(context).inflate(R.layout.list_item, parent, false); holder = new ViewHolder(); holder.nameTextView = convertView.findViewById(R.id.nameTextView); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } final Item item = itemList.get(position); holder.nameTextView.setText(item.getName()); convertView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(context, DetailActivity.class); intent.putExtra("url", item.getUrl()); context.startActivity(intent); } }); return convertView; } private static class ViewHolder { TextView nameTextView; } } ``` 在这个示例代码,我们实现了一个自定义的Adapter,其getView方法设置ListView点击事件。当用户点击其一项,我们将其URL作为Extra传递给DetailActivity,并启动该Activity。 最后,我们需要创建一个DetailActivity来显示用户点击的项目详细信息。在这个示例代码,我们使用一个WebView来加载该项目的URL。 ``` public class DetailActivity extends AppCompatActivity { private WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_detail); webView = findViewById(R.id.webView); String url = getIntent().getStringExtra("url"); webView.loadUrl(url); } } ``` 希望这个示例代码可以帮助你实现你的功能!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值