recyclerview无适配器连接;跳过布局

guykilcj  于 2021-06-30  发布在  Java
关注(0)|答案(30)|浏览(480)

刚刚实施 RecyclerView 在我的代码中,替换 ListView .
一切正常。显示数据。
但正在记录错误消息:

15:25:53.476 E/RecyclerView: No adapter attached; skipping layout

15:25:53.655 E/RecyclerView: No adapter attached; skipping layout

对于以下代码:

ArtistArrayAdapter adapter = new ArtistArrayAdapter(this, artists);
recyclerView = (RecyclerView) findViewById(R.id.cardList);
recyclerView.setHasFixedSize(true);
recyclerView.setAdapter(adapter);
recyclerView.setLayoutManager(new LinearLayoutManager(this));

如你所见,我已附加了一个适配器 RecyclerView . 那为什么我总是犯这个错误呢?
我读过与同一问题有关的其他问题,但没有一个有用。

8ehkhllq

8ehkhllq16#

ArtistArrayAdapter adapter = new ArtistArrayAdapter(this, artists);
recyclerView = (RecyclerView) findViewById(R.id.cardList);
recyclerView.setHasFixedSize(true);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
recyclerView.setAdapter(adapter);

只要用这个替换上面的代码就可以了。错误的是在调用布局管理器之前调用了setadapter(adapter)。

6qftjkof

6qftjkof17#

在Kotlin我们遇到了一个奇怪的不合逻辑的问题。
这不起作用:

mBinding.serviceProviderCertificates.apply {
            adapter = adapter
            layoutManager =  LinearLayoutManager(activity)
        }

当这起作用时:

mBinding.serviceProviderCertificates.adapter = adapter
mBinding.serviceProviderCertificates.layoutManager = LinearLayoutManager(activity)

一旦下班后我得到更多,我会分享更多的见解。

5cg8jx4n

5cg8jx4n18#

//当您在创建阶段没有设置适配器时会发生这种情况:当api响应开始工作时调用notifydatasetchanged()

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity);

        magazineAdapter = new MagazineAdapter(getContext(), null, this );
        newClipRecyclerView.setAdapter(magazineAdapter);
        magazineAdapter.notifyDataSetChanged();

       APICall();
}

public void APICall() {
    if(Response.isSuccessfull()){
    mRecyclerView.setAdapter(mAdapter);
   }
}
Just move setting the adapter into onCreate with an empty data and when you have the data call:

mAdapter.notifyDataSetChanged();
e5nszbig

e5nszbig19#

这真的是一个简单的错误,你得到的,没有必要在这做任何代码。发生此错误的原因是活动使用了错误的布局文件。通过ide,我自动创建了一个布局的布局v21,该布局成为活动的默认布局。我在旧布局文件和新布局文件中所做的所有代码都只有很少的xml代码,这导致了这个错误。
解决方案:复制旧布局的所有代码并粘贴到布局v21中

o2gm4chl

o2gm4chl20#

在我的情况下,它是一个被遗忘的组件,位于viewholder类中,但它不位于布局文件中

2jcobegt

2jcobegt21#

添加另一个答案,因为我发现这个线程谷歌的错误。我想初始化一个 PreferenceFragmentCompat 但我忘了在xml中夸大偏好 onCreatePreferences 这样地:

class SettingsFragment : PreferenceFragmentCompat() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        val inflater = LayoutInflater.from(context)
        inflater.inflate(R.layout.fragment_settings, null)
    }

    override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
        // Missing this line here:
        //   setPreferencesFromResource(R.xml.settings, rootKey)
    }
}

在我意识到之前,这个错误一直是个谜 PreferenceFragmentCompat 必须使用 RecyclerView 内部。

w8rqjzmb

w8rqjzmb22#

我已经解决了这个错误。您只需要添加布局管理器并添加空适配器。
像这样的代码:

myRecyclerView.setLayoutManager(...//your layout manager);
        myRecyclerView.setAdapter(new RecyclerView.Adapter() {
            @Override
            public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                return null;
            }

            @Override
            public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {

            }

            @Override
            public int getItemCount() {
                return 0;
            }
        });
//other code's 
// and for change you can use if(mrecyclerview.getadapter != speacialadapter){
//replice your adapter
//}
fgw7neuy

fgw7neuy23#

只需将以下内容添加到 RecyclerView ```
app:layoutManager="android.support.v7.widget.LinearLayoutManager"

例子:

<android.support.v7.widget.RecyclerView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"
app:layoutManager="android.support.v7.widget.LinearLayoutManager"
app:layout_constraintBottom_toTopOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">

</android.support.v7.widget.RecyclerView>
disbfnqx

disbfnqx24#

对于那些使用 RecyclerView片段中,并从其他视图将其充气:在充气整个片段视图时,请确保绑定 RecyclerView 到它的根视图。
我正在连接并正确地为适配器执行所有操作,但我从未执行绑定。这个由@prateek agarwal给出的答案对我来说已经足够了,但是这里有更多的细节。

Kotlin

override fun onCreateView(inflater: LayoutInflater?, container: ViewGroup?, savedInstanceState: Bundle?): View? {

    val rootView =  inflater?.inflate(R.layout.fragment_layout, container, false)
    recyclerView = rootView?.findViewById(R.id.recycler_view_id)
    // rest of my stuff
    recyclerView?.setHasFixedSize(true)
    recyclerView?.layoutManager = viewManager
    recyclerView?.adapter = viewAdapter
    // return the root view
    return rootView
}

java

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

    View rootView= inflater.inflate(R.layout.fragment_layout,container,false);
    recyclerview= rootView.findViewById(R.id.recycler_view_id);
    return rootView;
}
fsi0uk1n

fsi0uk1n25#

在我的情况下,我是在里面设置适配器 onLocationChanged() 在模拟器中进行回调和调试。因为它没有检测到位置改变,所以它从未开火。当我在模拟器的扩展控件中手动设置它们时,它按预期工作。

wgeznvg7

wgeznvg726#

我有这个问题,有几次的问题是循环查看放在scrollview对象中
在检查实现之后,原因似乎如下。如果将recyclerview放入scrollview中,那么在测量步骤中,它的高度是未指定的(因为scrollview允许任何高度),因此,它等于最小高度(根据实现),这显然是零。
您有两个选项可以解决此问题:
将一定高度设置为recyclerview
将scrollview.fillviewport设置为true
或者将recyclerview放在scrollview之外。在我看来,这是迄今为止最好的选择。如果recyclerview高度不受限制(在scrollview中就是这样),那么所有适配器的视图都有足够的垂直位置,可以一次创建所有视图。再也没有循环利用的观点了,这有点违背了循环利用观点的目的。
(可跟踪 android.support.v4.widget.NestedScrollView 以及)

r1wp621o

r1wp621o27#

我在这个问题上浪费了16分钟的时间,所以我要承认我犯了一个令人难以置信的尴尬错误——我使用butterknife,在这个片段中的oncreateview中绑定视图。
我花了很长时间才弄明白为什么没有layoutmanager,但是很明显视图是注入的,所以它们实际上不会为null,所以回收器永远不会为null。。哎呀!

@BindView(R.id.recycler_view)
RecyclerView recyclerView;

    @Override
public View onCreateView(......) {
    View v = ...;
    ButterKnife.bind(this, v);
    setUpRecycler()
 }

public void setUpRecycler(Data data)
   if (recyclerView == null) {
 /*very silly because this will never happen*/
       LinearLayoutManager linearLayoutManager = new LinearLayoutManager(getActivity());
       //more setup
       //...
    }
    recyclerView.setAdapter(new XAdapter(data));
}

如果您遇到这样的问题,请跟踪您的视图并使用 uiautomatorviewer

xiozqbni

xiozqbni28#

我有同样的错误,我修正了它这样做,如果你是等待数据像我一样使用改装或类似的东西
放在oncreate之前

private ArtistArrayAdapter adapter;
private RecyclerView recyclerView;

把它们放在你的oncreate里

recyclerView = (RecyclerView) findViewById(R.id.cardList);
 recyclerView.setHasFixedSize(true);
 recyclerView.setLayoutManager(new LinearLayoutManager(this));
 adapter = new ArtistArrayAdapter( artists , R.layout.list_item ,getApplicationContext());
 recyclerView.setAdapter(adapter);

当你收到数据时

adapter = new ArtistArrayAdapter( artists , R.layout.list_item ,getApplicationContext());
recyclerView.setAdapter(adapter);

现在进入你的ArtistarayAdapter类,做这个如果你的数组是空的或者是空的,它将使getitemcount返回0如果不是,它将使它成为Artisters数组的大小

@Override
public int getItemCount() {

    int a ;

    if(artists != null && !artists.isEmpty()) {

        a = artists.size();
    }
    else {

        a = 0;

     }

   return a;
}
0qx6xfy6

0qx6xfy629#

在创建阶段未设置适配器时会发生这种情况:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity);
    mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
    ....
}

public void onResume() {
    super.onResume();
    mRecyclerView.setAdapter(mAdapter);
    ....
}

只需将适配器设置移到oncreate中,并使用空数据调用,当您有数据调用时:

mAdapter.notifyDataSetChanged();
uz75evzq

uz75evzq30#

我和你有同样的情况,显示是可以的,但错误出现在locat。这就是我的解决方案:(1)初始化create()上的recyclerview&bind适配器

RecyclerView mRecycler = (RecyclerView) this.findViewById(R.id.yourid);
mRecycler.setAdapter(adapter);

(2) 获取数据时调用notifydatastatechanged

adapter.notifyDataStateChanged();

在recyclerview的源代码中,还有其他线程来检查数据的状态。

public RecyclerView(Context context, @Nullable AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    this.mObserver = new RecyclerView.RecyclerViewDataObserver(null);
    this.mRecycler = new RecyclerView.Recycler();
    this.mUpdateChildViewsRunnable = new Runnable() {
        public void run() {
            if(RecyclerView.this.mFirstLayoutComplete) {
                if(RecyclerView.this.mDataSetHasChangedAfterLayout) {
                    TraceCompat.beginSection("RV FullInvalidate");
                    RecyclerView.this.dispatchLayout();
                    TraceCompat.endSection();
                } else if(RecyclerView.this.mAdapterHelper.hasPendingUpdates()) {
                    TraceCompat.beginSection("RV PartialInvalidate");
                    RecyclerView.this.eatRequestLayout();
                    RecyclerView.this.mAdapterHelper.preProcess();
                    if(!RecyclerView.this.mLayoutRequestEaten) {
                        RecyclerView.this.rebindUpdatedViewHolders();
                    }

                    RecyclerView.this.resumeRequestLayout(true);
                    TraceCompat.endSection();
                }

            }
        }
    };

在dispatchlayout()中,我们可以发现其中有错误:

void dispatchLayout() {
    if(this.mAdapter == null) {
        Log.e("RecyclerView", "No adapter attached; skipping layout");
    } else if(this.mLayout == null) {
        Log.e("RecyclerView", "No layout manager attached; skipping layout");
    } else {

相关问题