Android Recyclerview 内部 fragment 显示 "No adapter attached; skipping layout "

标签 android android-fragments

如果我在一个扩展 AppCompatActivity 的类中编写这段代码 有效,但在 fragment 类中我不知道为什么它不起作用。 在有这个 fragment 的 Activity 中我使用另一个适配器 显示具有相同代码的产品并且有效

public class Categroy extends  Fragment{

    // CONNECTION_TIMEOUT and READ_TIMEOUT are in milliseconds
    public static final int CONNECTION_TIMEOUT = 10000;
    public static final int READ_TIMEOUT = 15000;
    public RecyclerView mRVcategoryList;
    public AdapterCategory mAdapter;
    private String myurl="http://10.0.3.2/mobilaApp/category.php";
    // private String categoryurl="http://10.0.3.2/mobilaApp/category.php";



    public LinearLayoutManager layoutManager;
    List<DataCategory> data=new ArrayList<>();
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // execute asyncLogin
        new AsyncLogin().execute();
    }
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                                  Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment_categroy, container,     false);
        RecyclerView recyclerView = (RecyclerView)   rootView.findViewById(R.id.rvcat);
        // 2. set layoutManger
        recyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));
        // 3. create an adapter
        AdapterCategory mAdapter = new          AdapterCategory(getActivity().getApplicationContext(), data);
        // 4. set adapter
        recyclerView.setAdapter(mAdapter);
        recyclerView.setItemAnimator(new DefaultItemAnimator());
        return rootView;
        }
    private class AsyncLogin extends AsyncTask<String, String, String> {
        ProgressDialog pdLoading = new ProgressDialog(getActivity());
        HttpURLConnection conn;
        URL url = null;
        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            //this method will be running on UI thread
            pdLoading.setMessage("\tLoading...");
            pdLoading.setCancelable(false);
            pdLoading.show();
        }
        @Override
        protected String doInBackground(String... params) {
            try {

                // Enter URL address where your json file resides
                // Even you can make call to php file which returns json data
                url = new URL(myurl);
                // urlcat = new URL(categoryurl);

            } catch (MalformedURLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
                return e.toString();
            }
            try {

                // Setup HttpURLConnection class to send and receive data from php and mysql
                conn = (HttpURLConnection) url.openConnection();
                conn.setReadTimeout(READ_TIMEOUT);
                conn.setConnectTimeout(CONNECTION_TIMEOUT);
                conn.setRequestMethod("GET");

                // setDoOutput to true as we recieve data from json file
                conn.setDoOutput(true);

            } catch (IOException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
                return e1.toString();
            }

            try {

                int response_code = conn.getResponseCode();

                // Check if successful connection made
                if (response_code == HttpURLConnection.HTTP_OK) {

                    // Read data sent from server
                    InputStream input = conn.getInputStream();
                    BufferedReader reader = new BufferedReader(new InputStreamReader(input));
                    StringBuilder result = new StringBuilder();
                    String line;
                    while ((line = reader.readLine()) != null) {
                        result.append(line);
                    }

                    // Pass data to onPostExecute method
                    return (result.toString());

                } else {

                    return ("unsuccessful");
                }

            } catch (IOException e) {
                e.printStackTrace();
                return e.toString();
            } finally {
                conn.disconnect();
            }
        }
        @Override
        protected void onPostExecute(String result) {

            //this method will be running on UI thread

            // dississ dialog   pdLoading.dismiss();

            pdLoading.dismiss();
            try {

                JSONArray jArray = new JSONArray(result);

                // Extract data from json and store into ArrayList as class objects
                for(int i=0;i<jArray.length();i++){
                    JSONObject json_data = jArray.getJSONObject(i);
                    DataCategory categorydata = new DataCategory();

                    categorydata.name_cat= json_data.getString("name_cat");


                    data.add(categorydata);
                }



                mRVcategoryList = (RecyclerView)getActivity(). findViewById(R.id.rvcat);
                mAdapter = new AdapterCategory(getActivity().getApplicationContext(), data);
                mRVcategoryList.setAdapter(mAdapter);
                mRVcategoryList.setLayoutManager(new LinearLayoutManager(getActivity().getApplicationContext()));

            } catch (JSONException e) {
                Toast.makeText(getActivity().getApplicationContext(), e.toString(), Toast.LENGTH_LONG).show();
            }

        }

    }
}
     /* if i write this code in a class extends AppCompatActivity it
        works but in a fragment class i don't know why it doesn't work .
        in the activity that has this fragment i use another adapter
        to show products with the same code and it works 
       */
  Adapter is here
                    public AdapterCategory(Context context, List<DataCategory> data){
    this.context=context;
    inflater= LayoutInflater.from(context);
    this.data=data;
  }

// Inflate the layout when viewholder created
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View view=inflater.inflate(R.layout.categoryrow, parent,false);
    MyHolder holder=new MyHolder(view);
    return holder;
}

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

    // Get current position of item in recyclerview to bind data and assign values from list
    MyHolder myHolder= (MyHolder) holder;
    DataCategory current=data.get(position);
    myHolder.namecat.setText(current.name_cat);




}

// return total item from List
@Override
public int getItemCount() {
    return data.size();
}


class MyHolder extends RecyclerView.ViewHolder{

    TextView namecat;





    // TextView textPrice;

    // create constructor to get widget reference
    public MyHolder(View itemView) {
        super(itemView);
        namecat= (TextView) itemView.findViewById(R.id.category_name);


    }

}

最佳答案

使用 getContext() 而不是 getActivity() 将 layoutManager 设置为您的 recyclerView,它将起作用。

mListLayoutManager=new LinearLayoutManager(getContext());
    recyclerView.setLayoutManager(mListLayoutManager);

关于Android Recyclerview 内部 fragment 显示 "No adapter attached; skipping layout ",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38785798/

相关文章:

android - 如何告诉我的自定义 FragmentPagerAdapter 停止销毁我的 Fragment?

java - 如何使用 AsyncTask 实时检索 RAM 消耗情况

android - 如何在 Android 中使用 Fragments

android - 在 Fragment 中使用 volley 从 JSON 中获取数据

android - 我如何从 Android 4.0 及更高版本的远程 URL 获取视频缩略图?

android - 从 Play 商店安装后无法检索推荐代码

更新到 2.3 后的 Android AVD 错误

java - Dagger 2 场注入(inject)在 Android 中不起作用

java - putExtra() 不适用于按钮 :onClick

java - Android onSaveInstanceState 未获取类变量