notice.vue 5.5 KB

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