notice.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <template>
  2. <view>
  3. <view class="cu-load padding-top-10" :class="ajax.loading?'loading':''" @tap="getHistoryMsg"></view>
  4. <view class="cart-view-box" v-for="(item,index) in msgList" :key="index" :id="`msg-${item.id}`">
  5. <view class="text-gray text-center">{{item.createTime}}</view>
  6. <view @click="goDetail(item)" class="bg-white margin-top radius card-view">
  7. <view class="content-view">
  8. <view class="text-black text-bold text-lg text-cut">{{item.title}}</view>
  9. <view class=" text-sm text-cut-2 subtitle">{{item.notice | formatHtml}}</view>
  10. <view class="flex justify-between padding-top-20" style=" border-top: 1rpx solid #f2f2f2;box-sizing: border-box;">
  11. <view class="text-df text-black">
  12. <text>查看详情</text>
  13. </view>
  14. <view style="padding-top: 8rpx;">
  15. <text class=" cuIcon-right"></text>
  16. </view>
  17. </view>
  18. </view>
  19. </view>
  20. </view>
  21. </view>
  22. </template>
  23. <script>
  24. var app=getApp()
  25. export default {
  26. components:{
  27. },
  28. data() {
  29. return {
  30. msgList:[],
  31. ajax:{
  32. rows:10, //每页数量
  33. page:1, //页码
  34. flag:true, // 请求开关
  35. loading:true, // 加载中
  36. },
  37. content:''
  38. }
  39. },
  40. filters: {
  41. formatHtml (str) {
  42. return str.replace(/<[^>]+>/g, "");
  43. }
  44. },
  45. mounted() {
  46. this.$nextTick(()=>{
  47. this.getHistoryMsg();
  48. });
  49. },
  50. onPageScroll(e){
  51. if(e.scrollTop<5){
  52. this.getHistoryMsg();
  53. }
  54. },
  55. onLoad() {
  56. },
  57. methods: {
  58. goDetail(item){
  59. app.globalData.noticeDetail=item
  60. uni.navigateTo({
  61. url:"/pages/index/notice/detail"
  62. })
  63. },
  64. // 获取历史消息
  65. getHistoryMsg(){
  66. if(!this.ajax.flag){
  67. return; //
  68. }
  69. // 此处用到 ES7 的 async/await 知识,为使代码更加优美。不懂的请自行学习。
  70. let get = async ()=>{
  71. this.hideLoadTips();
  72. this.ajax.flag = false;
  73. let data = await this.joinHistoryMsg();
  74. console.log(data); // 查看请求返回的数据结构
  75. // 获取待滚动元素选择器,解决插入数据后,滚动条定位时使用
  76. let selector = '';
  77. if(this.ajax.page>1){
  78. // 非第一页,则取历史消息数据的第一条信息元素
  79. selector = `#msg-${this.msgList[0].id}`;
  80. }else{
  81. // 第一页,则取当前消息数据的最后一条信息元素
  82. selector = `#msg-${data[data.length-1].id}`;
  83. }
  84. // 将获取到的消息数据合并到消息数组中
  85. this.msgList = [...data,...this.msgList];
  86. // 数据挂载后执行,不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。
  87. this.$nextTick(()=>{
  88. // 设置当前滚动的位置
  89. this.setPageScrollTo(selector);
  90. this.hideLoadTips(true);
  91. if(data.length < this.ajax.rows){
  92. // 当前消息数据条数小于请求要求条数时,则无更多消息,不再允许请求。
  93. // 可在此处编写无更多消息数据时的逻辑
  94. }else{
  95. this.ajax.page ++;
  96. // 延迟 200ms ,以保证设置窗口滚动已完成
  97. setTimeout(()=>{
  98. this.ajax.flag = true;
  99. },200)
  100. }
  101. })
  102. }
  103. get();
  104. },
  105. // 拼接历史记录消息,正式项目可替换为请求历史记录接口
  106. joinHistoryMsg(){
  107. let that=this
  108. // 此处用到 ES6 的 Promise 知识,不懂的请自行学习。
  109. return new Promise((done,fail)=>{
  110. // 无数据请求接口,由 setTimeout 模拟,正式项目替换为 ajax 即可。
  111. setTimeout(()=>{
  112. let params={
  113. agencyId:that.$cache.get('agencyId')
  114. }
  115. that.$api.notice.page(params).then(res=>{
  116. let data=res.data.records
  117. done(data.reverse());
  118. })
  119. },800);
  120. })
  121. },
  122. // 设置页面滚动位置
  123. setPageScrollTo(selector){
  124. let view = uni.createSelectorQuery().in(this).select(selector);
  125. view.boundingClientRect((res) => {
  126. uni.pageScrollTo({
  127. scrollTop:res.top - 30, // -30 为多显示出大半个消息的高度,示意上面还有信息。
  128. duration: 0
  129. });
  130. }).exec();
  131. },
  132. // 隐藏加载提示
  133. hideLoadTips(flag){
  134. if(flag){
  135. console.log("333");
  136. setTimeout(()=>{
  137. this.ajax.loading = false;
  138. },300);
  139. }else{
  140. this.ajax.loading = true;
  141. }
  142. },
  143. },
  144. }
  145. </script>
  146. <style lang="scss">
  147. page{
  148. background-color: #F3F3F3;
  149. font-size: 28rpx;
  150. }
  151. .subtitle{
  152. color: #7e7e7e;
  153. font-size: 28rpx;
  154. margin: 50rpx 0 10rpx 0;
  155. line-height: 52rpx;
  156. }
  157. .cart-view-box {
  158. padding: 36.36rpx 27.27rpx;
  159. .card-view {
  160. background-color: #FFFFFF;
  161. position: relative;
  162. border-radius: 10rpx;
  163. .head-img {
  164. width: 100%;
  165. height: 236.36rpx;
  166. border-radius: 9.09rpx 9.09rpx 0 0;
  167. }
  168. .content-view {
  169. padding: 27.27rpx;
  170. }
  171. }
  172. }
  173. </style>