fs-loadmore.vue 1.3 KB

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