fs-loadmore.vue 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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, toRef } 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. autoCall: {
  26. type: Boolean,
  27. default: true
  28. },
  29. nomore: {
  30. type: String,
  31. default: '没有更多了~'
  32. }
  33. })
  34. const emits = defineEmits(['update:modelValue'])
  35. const state = reactive({
  36. loading: true,
  37. dataList: props.modelValue,
  38. pageNo: 1,
  39. pageSize: props.pageSize,
  40. hasMore: true
  41. })
  42. const query = loadmore => {
  43. state.loading = true
  44. if (loadmore) {
  45. state.pageNo++
  46. } else {
  47. state.pageNo = 1
  48. }
  49. return props
  50. .fetchList({
  51. pageNo: state.pageNo,
  52. pageSize: props.pageSize
  53. })
  54. .then(res => {
  55. state.hasMore = res.length >= state.pageSize
  56. state.dataList = loadmore ? [...state.dataList, ...res] : res
  57. emits('update:modelValue', state.dataList)
  58. })
  59. .finally(() => {
  60. state.loading = false
  61. })
  62. }
  63. props.autoCall && query()
  64. const refresh = () => {
  65. state.dataList = []
  66. emits('update:modelValue', state.dataList)
  67. return query()
  68. }
  69. defineExpose({
  70. query,
  71. refresh,
  72. hasMore: toRef(state, 'hasMore'),
  73. pullDownRefresh: props.pullDownRefresh
  74. })
  75. </script>
  76. <style></style>