fs-loadmore.vue 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <template>
  2. <view>
  3. <slot></slot>
  4. <fs-empty v-if="!state.loading && !state.dataList.length"></fs-empty>
  5. <template v-else>
  6. <fs-divider v-if="!state.hasMore">{{nomore}}</fs-divider>
  7. </template>
  8. </view>
  9. </template>
  10. <script setup>
  11. import { reactive } from 'vue'
  12. const props = defineProps({
  13. modelValue: {
  14. type: Array,
  15. default() {
  16. return []
  17. }
  18. },
  19. fetchList: Function,
  20. pageSize: {
  21. type: Number,
  22. default: 20
  23. },
  24. pullDownRefresh: Boolean,
  25. nomore: {
  26. type: String,
  27. default: '没有更多了~'
  28. }
  29. })
  30. const emits = defineEmits(['update:modelValue'])
  31. const state = reactive({
  32. loading: true,
  33. dataList: props.modelValue,
  34. pageNo: 1,
  35. pageSize: props.pageSize,
  36. hasMore: true
  37. })
  38. const query = (loadmore) => {
  39. state.loading = true
  40. if (loadmore) {
  41. state.pageNo++
  42. } else{
  43. state.pageNo = 1
  44. }
  45. return props.fetchList({
  46. pageNo: state.pageNo,
  47. pageSize: props.pageSize
  48. }).then(res => {
  49. state.hasMore = res.length >= state.pageSize
  50. state.dataList = loadmore ? [...state.dataList, ...res] : res
  51. state.loading = false
  52. emits('update:modelValue', state.dataList)
  53. })
  54. }
  55. const refresh = () => {
  56. state.dataList = []
  57. emits('update:modelValue', state.dataList)
  58. query()
  59. }
  60. query()
  61. defineExpose({
  62. query,
  63. refresh,
  64. hasMore: state.hasMore,
  65. pullDownRefresh: props.pullDownRefresh
  66. })
  67. </script>
  68. <style>
  69. </style>