notice.vue 5.4 KB

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