首页 > 解决方案 > 无法在回收站视图中显示空视图

问题描述

当我的列表在回收站视图中为空但它不起作用时,我试图放置一个空视图。我尝试了以下代码:

public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        view = inflater.inflate(R.layout.fragment_notification, container, false);
        ((AppCompatActivity) getActivity()).getSupportActionBar().show();
        initVar();
        initViews();
        loadData();
        if (notifications.isEmpty()){
            recyclerView.setVisibility(View.GONE);
            imageView.setVisibility(View.VISIBLE);
        }
        else {
            recyclerView.setVisibility(View.VISIBLE);
            imageView.setVisibility(View.GONE);
        }
        return view;
    }

和 XML 代码:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

            <androidx.recyclerview.widget.RecyclerView
                android:id="@+id/notification_recycler_view"
                android:layout_width="match_parent"
                android:layout_height="match_parent" />

            <ImageView
                android:id="@+id/empty_iv_notification"
                android:layout_width="200dp"
                android:layout_height="200dp"
                android:layout_gravity="center"
                android:visibility="gone"
                android:src="@drawable/ic_empty" />
</LinearLayout>

如你看到的 -即使列表有数据也显示空视图

虽然列表有数据,但它仍然显示空视图。我无法用stackoverflow答案帮助自己,因为我尝试的所有答案都是相同的并且不起作用。有谁能够帮我。

标签: androidandroid-recyclerview

解决方案


当你的数据被加载时,把下面的代码放在 loadData() 我的意思是如果你的列表是空的,那么下面的代码就会被执行。

 if (notifications.isEmpty()){
            recyclerView.setVisibility(View.GONE);
            imageView.setVisibility(View.VISIBLE);
        }
        else {
            recyclerView.setVisibility(View.VISIBLE);
            imageView.setVisibility(View.GONE);
        }

推荐阅读