使用Kotlin检索数据的Firestore错误

KARUNESH PALEKAR

我正在尝试使用MVVM模式从Firebase Firestore检索数据。每次构建都会成功,但是应用无法打开。我无法在代码中找到错误。应用程序可以添加数据,但要检索数据是问题。请帮忙。谢谢

视图模型

import android.util.Log
import androidx.lifecycle.LiveData
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel
import com.google.firebase.firestore.FirebaseFirestore

import com.karuneshpalekar.firestorepagination.models.Note
import java.lang.Exception
class DataViewModel : ViewModel() {

    companion object{
        private const val  TAG =" VIEWMODEL"
    }
    private val db = FirebaseFirestore.getInstance()
    private val noteref = db.collection("record")

    private val _results = MutableLiveData<Exception>()
    val results: LiveData<Exception>
        get() = _results

    private val _notes = MutableLiveData<List<Note>>()
    val notes: LiveData<List<Note>>
        get() = _notes
    fun addData(note: Note) {
        noteref.add(note).addOnCompleteListener {
            if (it.isSuccessful) {
                Log.w("TAG", "success")
                _results.value = null
            } else {
                _results.value = it.exception
            }
        }
    }
    fun fetchData() {

        noteref.addSnapshotListener{ snapshot,e->

            if (e!=null){
                Log.w(TAG,"Listen failed",e)
                return@addSnapshotListener
            }

            if (snapshot != null) {
               val items = mutableListOf<Note>()
                for (docs in snapshot){
                    val notes  = docs.toObject(Note::class.java)
                    notes.let {
                        items.add(it)
                    }
                    _notes.value = items
                }

            }
        }
    }
}

适配器


import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import com.karuneshpalekar.firestorepagination.R
import com.karuneshpalekar.firestorepagination.models.Note
import kotlinx.android.synthetic.main.list_item.view.*

class DataAdapter : RecyclerView.Adapter<RecyclerView.ViewHolder>() {

    private var items= mutableListOf<Note>()
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder {
        return DataViewHolder(
            LayoutInflater.from(parent.context).inflate(R.layout.list_item, parent, false)
        )
    }

    override fun getItemCount(): Int {

        return items.size
    }

    override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) {

        when (holder) {
            is DataViewHolder -> {
                holder.bind(items[position])
            }
        }


    }

    fun setNote(items:List<Note>){
        this.items = items as MutableList<Note>
        notifyDataSetChanged()
    }



    class DataViewHolder constructor(itemView: View) : RecyclerView.ViewHolder(itemView) {

        private val textName = itemView.text_view_name
        fun bind(note: Note) {
            textName.text = note.name
        }

    }
}

分段

import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.lifecycle.Observer
import androidx.lifecycle.ViewModelProviders
import com.karuneshpalekar.firestorepagination.R
import kotlinx.android.synthetic.main.fragment_recyclerview.*


class RecyclerView : Fragment() {


    private lateinit var viewModel: DataViewModel
    private lateinit var dataadapter : DataAdapter
    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        viewModel = ViewModelProviders.of(this).get(DataViewModel::class.java)
        return inflater.inflate(R.layout.fragment_recyclerview, container, false)
    }

   override fun onActivityCreated(savedInstanceState: Bundle?) {
        super.onActivityCreated(savedInstanceState)

       recycler_view.apply {
           dataadapter = DataAdapter()
           adapter = dataadapter
       }


       viewModel.fetchData()

       viewModel.notes.observe(viewLifecycleOwner, Observer {
           dataadapter.setNote(it)
       })

        floating_btn_add.setOnClickListener {
            DialogFragment().show(childFragmentManager, "")

        }
    }
}

DialogFragment-添加数据

class DialogFragment :DialogFragment(){

    private lateinit var viewmodel:DataViewModel


    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        viewmodel = ViewModelProviders.of(this).get(DataViewModel::class.java)
        return inflater.inflate(R.layout.fragment_dialog, container, false)
    }
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setStyle(STYLE_NO_TITLE, android.R.style.Theme_DeviceDefault_Light_Dialog_MinWidth)
    }

    override fun onActivityCreated(savedInstanceState: Bundle?) {
        super.onActivityCreated(savedInstanceState)
        viewmodel.results.observe(viewLifecycleOwner, Observer {
            val message = if (it == null) {
            getString(R.string.name_added)
        } else {
            getString(R.string.name_error)
        }
            Toast.makeText(requireContext(), message, Toast.LENGTH_SHORT).show()
            dismiss()

        })

        button_add.setOnClickListener {
            val names = edit_text_name.text.toString().trim()
            val note= Note("",names)
            viewmodel.addData(note)

        }

    }

}

RecyclerView XML

<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    tools:context=".ui.RecyclerView">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="@dimen/margin"
        app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
        tools:listitem="@layout/list_item"
        />

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/floating_btn_add"
        app:fabSize="normal"
        android:layout_gravity="bottom|end"
        android:layout_margin="@dimen/margin"
        />



</androidx.coordinatorlayout.widget.CoordinatorLayout>

以上是我的项目代码

KARUNESH PALEKAR

提供错误的代码中唯一缺少的是在Model类(即Note类)中没有进行空检查。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

使用React检索文档数据Firestore

来自分类Dev

检索数据后 Firestore Spinner 错误传递列表

来自分类Dev

SearchView使用列表视图检索错误的数据

来自分类Dev

使用Firebase Swift错误检索数据

来自分类Dev

无法在 Firestore 查询中使用 whereLessThan() 和 whereGreaterThan() 检索数据

来自分类Dev

检索错误数据

来自分类Dev

检索错误的数据

来自分类Dev

SQLITE 检索数据错误

来自分类Dev

我想从 firestore 中检索当前记录的用户数据,但此显示错误

来自分类Dev

使用Python检索Twitter数据时出现Unicode解码错误

来自分类Dev

SQL Server-使用错误的编码检索数据

来自分类Dev

MySQL / Hibernate使用映射为LocalTime的列检索错误的数据

来自分类Dev

使用Javascript从Firebase检索数据时出现错误

来自分类Dev

SQL Server-使用错误的编码检索数据

来自分类Dev

使用Firestore UI从Firestore检索数据并在RecyclerView中显示数据不适用于API 24+

来自分类Dev

HTTPS 数据检索错误

来自分类Dev

FirebaseUI Firestore 未在 iOS 上检索数据

来自分类Dev

使用Kotlin从Firebase检索HashMap

来自分类Dev

使用FirebaseDatabase检索数据

来自分类Dev

使用onPress检索数据

来自分类Dev

使用NSURLConnection检索数据

来自分类Dev

创建动态变量名称以使用JavaScript从Firestore检索数据

来自分类Dev

Flutter&Cloud_Firestore:使用2个“ where”条件时无法检索数据

来自分类Dev

如何使用HMTL / Javascript从Firestore db中的文档中检索数据

来自分类Dev

如何使用Firebase函数从Firestore检索文档并从另一个Firestore文档添加新数据?

来自分类Dev

如何从 Kotlin 中的 SearchView 正确检索数据?

来自分类Dev

使用循环中的查询从 CloudKit 获取数据会检索错误的数据

来自分类Dev

无法使用Flutter从Firestore检索文档

来自分类Dev

Flutter使用Stream检索Firestore集合

Related 相关文章

  1. 1

    使用React检索文档数据Firestore

  2. 2

    检索数据后 Firestore Spinner 错误传递列表

  3. 3

    SearchView使用列表视图检索错误的数据

  4. 4

    使用Firebase Swift错误检索数据

  5. 5

    无法在 Firestore 查询中使用 whereLessThan() 和 whereGreaterThan() 检索数据

  6. 6

    检索错误数据

  7. 7

    检索错误的数据

  8. 8

    SQLITE 检索数据错误

  9. 9

    我想从 firestore 中检索当前记录的用户数据,但此显示错误

  10. 10

    使用Python检索Twitter数据时出现Unicode解码错误

  11. 11

    SQL Server-使用错误的编码检索数据

  12. 12

    MySQL / Hibernate使用映射为LocalTime的列检索错误的数据

  13. 13

    使用Javascript从Firebase检索数据时出现错误

  14. 14

    SQL Server-使用错误的编码检索数据

  15. 15

    使用Firestore UI从Firestore检索数据并在RecyclerView中显示数据不适用于API 24+

  16. 16

    HTTPS 数据检索错误

  17. 17

    FirebaseUI Firestore 未在 iOS 上检索数据

  18. 18

    使用Kotlin从Firebase检索HashMap

  19. 19

    使用FirebaseDatabase检索数据

  20. 20

    使用onPress检索数据

  21. 21

    使用NSURLConnection检索数据

  22. 22

    创建动态变量名称以使用JavaScript从Firestore检索数据

  23. 23

    Flutter&Cloud_Firestore:使用2个“ where”条件时无法检索数据

  24. 24

    如何使用HMTL / Javascript从Firestore db中的文档中检索数据

  25. 25

    如何使用Firebase函数从Firestore检索文档并从另一个Firestore文档添加新数据?

  26. 26

    如何从 Kotlin 中的 SearchView 正确检索数据?

  27. 27

    使用循环中的查询从 CloudKit 获取数据会检索错误的数据

  28. 28

    无法使用Flutter从Firestore检索文档

  29. 29

    Flutter使用Stream检索Firestore集合

热门标签

归档