综合办公系统
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

mescroll-swiper-item.vue 3.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <template>
  2. <!--
  3. swiper中的transfrom会使fixed失效,此时用height="100%"固定高度;
  4. swiper中无法触发mescroll-mixins.js的onPageScroll和onReachBottom方法,只能用mescroll-uni,不能用mescroll-body
  5. -->
  6. <!-- ref动态生成: 字节跳动小程序编辑器不支持一个页面存在相同的ref (如不考虑字节跳动小程序可固定值为 ref="mescrollRef") -->
  7. <mescroll-uni :ref="'mescrollRef'+i" @init="mescrollInit" height="100%" top="60" :down="downOption" @down="downCallback" :up="upOption" @up="upCallback" @emptyclick="emptyClick">
  8. <!-- 数据列表 -->
  9. <good-list :list="goods"></good-list>
  10. </mescroll-uni>
  11. </template>
  12. <script>
  13. import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";
  14. import MescrollMoreItemMixin from "@/components/mescroll-uni/mixins/mescroll-more-item.js";
  15. import {apiSearch} from "@/api/mock.js"
  16. export default {
  17. mixins: [MescrollMixin,MescrollMoreItemMixin], // 注意此处还需使用MescrollMoreItemMixin (必须写在MescrollMixin后面)
  18. data() {
  19. return {
  20. downOption:{
  21. auto:false // 不自动加载 (mixin已处理第一个tab触发downCallback)
  22. },
  23. upOption:{
  24. auto:false, // 不自动加载
  25. // page: {
  26. // num: 0, // 当前页码,默认0,回调之前会加1,即callback(page)会从1开始
  27. // size: 10 // 每页数据的数量
  28. // },
  29. noMoreSize: 4, //如果列表已无数据,可设置列表的总数量要大于半页才显示无更多数据;避免列表数据过少(比如只有一条数据),显示无更多数据会不好看; 默认5
  30. empty:{
  31. tip: '~ 空空如也 ~', // 提示
  32. btnText: '去看看'
  33. }
  34. },
  35. goods: [] //列表数据
  36. }
  37. },
  38. props:{
  39. i: Number, // 每个tab页的专属下标 (除了支付宝小程序必须在这里定义, 其他平台都可不用写, 因为已在MescrollMoreItemMixin定义)
  40. index: { // 当前tab的下标 (除了支付宝小程序必须在这里定义, 其他平台都可不用写, 因为已在MescrollMoreItemMixin定义)
  41. type: Number,
  42. default(){
  43. return 0
  44. }
  45. },
  46. tabs: { // 为了请求数据,演示用,可根据自己的项目判断是否要传
  47. type: Array,
  48. default(){
  49. return []
  50. }
  51. }
  52. },
  53. methods: {
  54. /*下拉刷新的回调 */
  55. downCallback() {
  56. // 这里加载你想下拉刷新的数据, 比如刷新轮播数据
  57. // loadSwiper();
  58. // 下拉刷新的回调,默认重置上拉加载列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )
  59. this.mescroll.resetUpScroll()
  60. },
  61. /*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
  62. upCallback(page) {
  63. //联网加载数据
  64. let keyword = this.tabs[this.i].name
  65. apiSearch(page.num, page.size, keyword).then(curPageData=>{
  66. //联网成功的回调,隐藏下拉刷新和上拉加载的状态;
  67. this.mescroll.endSuccess(curPageData.length);
  68. //设置列表数据
  69. if(page.num == 1) this.goods = []; //如果是第一页需手动制空列表
  70. this.goods=this.goods.concat(curPageData); //追加新数据
  71. }).catch(()=>{
  72. //联网失败, 结束加载
  73. this.mescroll.endErr();
  74. })
  75. },
  76. //点击空布局按钮的回调
  77. emptyClick(){
  78. uni.showToast({
  79. title:'点击了按钮,具体逻辑自行实现'
  80. })
  81. }
  82. }
  83. }
  84. </script>