综合办公系统
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

beibei.vue 2.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <template>
  2. <view>
  3. <!-- 模拟的标题 -->
  4. <image class="header" src="https://www.mescroll.com/img/beibei/header.jpg" mode="aspectFit"/>
  5. <mescroll-body-diy ref="mescrollRef" @init="mescrollInit" top="180" bottom="100" @down="downCallback" @up="upCallback">
  6. <!-- 模拟的内容 -->
  7. <image src="https://www.mescroll.com/img/beibei/beibei1.jpg" mode="widthFix"/>
  8. <image src="https://www.mescroll.com/img/beibei/beibei2.jpg" mode="widthFix"/>
  9. <!-- 分页的数据列表 -->
  10. <good-list :list="goods"></good-list>
  11. </mescroll-body-diy>
  12. <!-- 模拟的底部 -->
  13. <image class="footer" src="https://www.mescroll.com/img/beibei/footer.jpg" mode="aspectFit"/>
  14. </view>
  15. </template>
  16. <script>
  17. import MescrollBodyDiy from "@/components/mescroll-diy/beibei/mescroll-body.vue";
  18. import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";
  19. import {apiGoods} from "@/api/mock.js"
  20. export default {
  21. mixins: [MescrollMixin], // 使用mixin (在main.js注册全局组件)
  22. components: {
  23. MescrollBodyDiy // 避免与main.js注册的全局组件名称相同,否则注册组件失效(iOS真机 APP HBuilderX2.7.9)
  24. },
  25. data() {
  26. return {
  27. goods: [] // 数据列表
  28. }
  29. },
  30. methods: {
  31. /*下拉刷新的回调 */
  32. downCallback() {
  33. // 这里加载你想下拉刷新的数据, 比如刷新轮播数据
  34. // loadSwiper();
  35. // 下拉刷新的回调,默认重置上拉加载列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )
  36. this.mescroll.resetUpScroll()
  37. },
  38. /*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
  39. upCallback(page) {
  40. //联网加载数据
  41. apiGoods(page.num, page.size).then(curPageData=>{
  42. //联网成功的回调,隐藏下拉刷新和上拉加载的状态;
  43. this.mescroll.endSuccess(curPageData.length);
  44. //设置列表数据
  45. if(page.num == 1) this.goods = []; //如果是第一页需手动制空列表
  46. this.goods=this.goods.concat(curPageData); //追加新数据
  47. }).catch(()=>{
  48. //联网失败, 结束加载
  49. this.mescroll.endErr();
  50. })
  51. }
  52. }
  53. }
  54. </script>
  55. <style>
  56. image{width: 100%;vertical-align: bottom;height:auto}
  57. .header{z-index: 9900;position: fixed;top: --window-top;left: 0;height: 180upx;background: white;}
  58. .footer{z-index: 9900;position: fixed;bottom: 0;left: 0;height: 100upx;background: white;}
  59. </style>