tr-consume.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <template>
  2. <view class="tr-consume_content">
  3. <!-- :enable-back-to-top="current_index===tab_index" 在微信小程序上可以多加这一句,因为默认是允许点击返回顶部的,但是这个页面有多个scroll-view,会全部返回顶部,所以需要控制是当前index才允许点击返回顶部 -->
  4. <!-- 如果当前页已经加载过数据或者当前切换到的tab是当前页,才展示当前页数据(懒加载) -->
  5. <view class="total-expend_coins">
  6. <view class="total-expend_coins__title">累计使用书币</view>
  7. <view class="total-expend_coins__coin">{{total_number}}</view>
  8. </view>
  9. <z-paging v-if="first_loaded || is_currentPage"
  10. ref="paging"
  11. v-model="data_list"
  12. :default-page-size="15"
  13. @query="queryList"
  14. :fixed="false">
  15. <!-- 如果希望其他view跟着页面滚动,可以放在z-paging标签内 -->
  16. <view class="list" v-for="(item,index) in data_list" :key="index" @click="itemClick(item)">
  17. <view class="item">
  18. <view class="item__info">
  19. <view class="item__info__title">订阅章节</view>
  20. <view class="item__info__date">{{item.create_at}}</view>
  21. </view>
  22. <view class="item__book">
  23. <view class="item__book__name">{{item.book_name}}</view>
  24. <view class="item__book__chapter">{{item.chapter_name}}</view>
  25. </view>
  26. <view class="item__coin">
  27. -{{item.coin}}书币
  28. </view>
  29. </view>
  30. </view>
  31. </z-paging>
  32. </view>
  33. </template>
  34. <script setup lang="ts">
  35. import { nextTick, ref, watch } from 'vue';
  36. import { trading_record_item_data } from '../../data/data';
  37. import { tools } from '../../framework/tools';
  38. let data_list = ref([]) //v-model绑定的这个变量不要在分页请求结束中自己赋值!!!
  39. let first_loaded = ref(false) //当前组件是否已经加载过了
  40. let is_currentPage = ref(false) //是否滚动到当前页
  41. let total_number = ref(0)
  42. const paging = ref(null) //$ref:paging
  43. const props = defineProps({
  44. tab_index: Number, //当前组件的index,也就是当前组件是swiper中的第几个
  45. current_index:Number, // 当前swiper切换到第几个index
  46. })
  47. watch(()=>props.current_index, (new_v,old_v)=>{
  48. if(new_v === props.tab_index){
  49. // 懒加载,当滑动到当前的item时,才去加载
  50. if(!first_loaded.value){
  51. first_loaded.value = true
  52. // 这里需要延迟渲染z-paging的原因是为了避免在一些平台上立即渲染可能引发的底层报错问题
  53. nextTick(()=>{
  54. setTimeout(() => {
  55. is_currentPage.value = true
  56. }, 100);
  57. })
  58. }
  59. }
  60. },{immediate:true})
  61. function queryList(pageNum:number, pageSize:number) {
  62. // console.log('pageNum=',pageNum,'pageSize=',pageSize)
  63. tools.requestOrderList(2,pageNum,pageSize,(data)=>{
  64. // console.log('消费data=',data)
  65. if(data) {
  66. if (pageNum == 1) {
  67. data_list.value = []
  68. total_number.value = data.total_number
  69. }
  70. paging.value.complete(data.list)
  71. data_list.value = data_list.value.concat(data.list)
  72. } else {
  73. paging.value.complete(false)
  74. }
  75. })
  76. }
  77. function itemClick(item_data:trading_record_item_data) {
  78. }
  79. </script>
  80. <style lang="scss">
  81. /* 注意:父节点需要固定高度,z-paging的height:100%才会生效 */
  82. .tr-consume_content {
  83. height: 100%;
  84. background-color: #ffffff;
  85. .total-expend_coins{
  86. display: flex;
  87. flex-direction: row;
  88. justify-content: space-between;
  89. font-size: 15px;
  90. color: #737373;
  91. padding: 0 30rpx;
  92. padding-top: 20rpx;
  93. &__title{}
  94. &__coin{}
  95. }
  96. .list{
  97. display: flex;
  98. justify-content: center;
  99. .item{
  100. margin-top: 4%;
  101. display: flex;
  102. flex-direction: row;
  103. width: 88%;
  104. padding: 3% 3%;
  105. border-radius: 20rpx;
  106. box-shadow: 0 0 5px 1px rgba(0, 0, 0, 0.1);
  107. background-color: #ffffff;
  108. &__info{
  109. width: 40%;
  110. &__title {
  111. font-size: 17px;
  112. color: #000;
  113. white-space: nowrap; /* 防止文本换行 */
  114. overflow: hidden; /* 隐藏溢出的文本 */
  115. text-overflow: ellipsis; /* 超出部分显示为省略号 */
  116. }
  117. &__date{
  118. margin-top: 16rpx;
  119. font-size: 13px;
  120. color: #6D6D6D;
  121. white-space: nowrap; /* 防止文本换行 */
  122. overflow: hidden; /* 隐藏溢出的文本 */
  123. text-overflow: ellipsis; /* 超出部分显示为省略号 */
  124. }
  125. }
  126. &__book{
  127. width: 40%;
  128. &__name {
  129. font-size: 17px;
  130. color: #000;
  131. white-space: nowrap; /* 防止文本换行 */
  132. overflow: hidden; /* 隐藏溢出的文本 */
  133. text-overflow: ellipsis; /* 超出部分显示为省略号 */
  134. }
  135. &__chapter{
  136. margin-top: 16rpx;
  137. font-size: 13px;
  138. color: #6D6D6D;
  139. white-space: nowrap; /* 防止文本换行 */
  140. overflow: hidden; /* 隐藏溢出的文本 */
  141. text-overflow: ellipsis; /* 超出部分显示为省略号 */
  142. }
  143. }
  144. &__coin{
  145. margin-top: 2%;
  146. display: flex;
  147. justify-content: right;
  148. width: 20%;
  149. font-size: 15px;
  150. color: #FF133A;
  151. }
  152. }
  153. }
  154. }
  155. </style>