notice.vue 5.0 KB

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