home.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. <template>
  2. <view>
  3. <view style="z-index: 999;">
  4. <u-navbar title="中正云学堂" :is-back="false">
  5. <view class="slot-wrap"><image src="/static/search.png" class="search" @click="jumpSearch"></image></view>
  6. </u-navbar>
  7. </view>
  8. <scroll-view scroll-y="true" @scroll="scroll" :style="'height: ' + windowHeight + 'px;'" @scrolltolower="scrollTolower">
  9. <view class="box">
  10. <view class="my_swiper"><u-swiper :list="list" @click="swiperClick" height="330" border-radius="25" mode="none"></u-swiper></view>
  11. <!-- 日历-->
  12. <view class="calendar_card">
  13. <view class="card_box">
  14. <u-row gutter="16">
  15. <u-col span="11" v-if="false">
  16. <view >
  17. <text class="t1">距离</text>
  18. <text class="t2">二级建造师</text>
  19. <text class="t1">考试</text>
  20. <text class="t3">365</text>
  21. <text class="t1">天,继续加油哦!</text>
  22. </view>
  23. </u-col>
  24. <u-col offset="11" span="1">
  25. <view @click="jumpPlan"><image src="/static/more.png" class="img_more"></image></view>
  26. </u-col>
  27. </u-row>
  28. </view>
  29. <u-line color="#EEEEEE" />
  30. <view style="width: 100%;display: flex;justify-content:center;margin-top: 20rpx;">
  31. <view v-for="(item, index) in date" :key="index" class="card_date">{{ item }}</view>
  32. </view>
  33. <view style="width: 100%;display: flex;justify-content:center;margin-top: 40rpx;">
  34. <view v-for="(item, index) in date_num" :key="index" class="date_num">{{ item }}</view>
  35. </view>
  36. <view style="width: 100%;margin-top: 20rpx;" v-if="false">
  37. <u-row gutter="16">
  38. <u-col span="2" text-align="center">
  39. <view><image src="/static/left.png" class="arr-icon"></image></view>
  40. </u-col>
  41. <u-col span="8" text-align="center"><view class="course_title">二级建造师市政公用工程</view></u-col>
  42. <u-col span="2" text-align="center">
  43. <view><image src="/static/right.png" class="arr-icon"></image></view>
  44. </u-col>
  45. </u-row>
  46. </view>
  47. </view>
  48. <!-- 筛选-->
  49. <view style="margin-top: 20rpx;">
  50. <u-row gutter="16">
  51. <u-col span="1">
  52. <view style="padding: 5rpx;"><image src="/static/select.png" class="arr-icon" @click="show = false"></image></view>
  53. </u-col>
  54. <u-col span="11">
  55. <view>
  56. <u-subsection
  57. @change="sectionChange"
  58. height="54"
  59. button-color="#2F4379"
  60. bg-color="#F8F9FF"
  61. active-color="#FFFFFF"
  62. inactive-color="#636A75"
  63. :list="tab_list"
  64. :current="current"
  65. ></u-subsection>
  66. </view>
  67. </u-col>
  68. </u-row>
  69. </view>
  70. <!-- 课程列表-->
  71. <view v-if="current == 0">
  72. <view @click="jumpDetail(item)" class="list_box" v-for="(item, index) in list1" :key="index">
  73. <image :src="$method.splitImgHost(item.coverUrl)" class="list_img"></image>
  74. <view class="list_content">
  75. <view style="margin-left: 280rpx;margin-top: 10rpx;">
  76. <view class="list_title">{{ item.courseName }}</view>
  77. <view class="old_price">原价:¥{{ item.price }}</view>
  78. <view class="price">现价:¥{{ item.price }}</view>
  79. </view>
  80. </view>
  81. </view>
  82. </view>
  83. <!-- 题库列表-->
  84. <view v-if="current == 1">
  85. <view @click="jumpDetail(item)" class="list_box" v-for="(item, index) in list2" :key="index">
  86. <image :src="$method.splitImgHost(item.coverUrl)" class="list_img"></image>
  87. <view class="list_content">
  88. <view style="margin-left: 280rpx;margin-top: 10rpx;">
  89. <view class="list_title">{{ item.bankName }}</view>
  90. <view class="old_price">原价:¥{{ item.price }}</view>
  91. <view class="price">现价:¥{{ item.price }}</view>
  92. </view>
  93. </view>
  94. </view>
  95. </view>
  96. <!-- 重点列表-->
  97. <view v-if="current == 2">
  98. <view @click="jumpDetail(item)" class="list_box" v-for="(item, index) in list3" :key="index">
  99. <image :src="$method.splitImgHost(item.coverUrl)" class="list_img"></image>
  100. <view class="list_content">
  101. <view style="margin-left: 280rpx;margin-top: 10rpx;">
  102. <view class="list_title">{{ item.name }}</view>
  103. <view class="old_price">原价:¥{{ item.price }}</view>
  104. <view class="price">现价:¥{{ item.price }}</view>
  105. </view>
  106. </view>
  107. </view>
  108. </view>
  109. <view v-if="paramList[current].showStatus" style="text-align: center;margin-top: 24rpx;">到底啦~</view>
  110. <u-popup v-model="show">
  111. <view style="width: 600rpx"><view class="popup_t1">选择你需要的</view></view>
  112. </u-popup>
  113. </view>
  114. </scroll-view>
  115. </view>
  116. </template>
  117. <script>
  118. export default {
  119. name: 'home',
  120. data() {
  121. return {
  122. show: false,
  123. tab_list: [
  124. {
  125. name: '课程'
  126. },
  127. {
  128. name: '刷题'
  129. },
  130. {
  131. name: '重点考点'
  132. }
  133. ],
  134. current: 0,
  135. list: [],
  136. paramList: [
  137. {
  138. pageNum: 1,
  139. pageSize: 10,
  140. total: 0,
  141. showStatus: 0
  142. },
  143. {
  144. pageNum: 1,
  145. pageSize: 10,
  146. total: 0,
  147. showStatus: 0
  148. },
  149. {
  150. pageNum: 1,
  151. pageSize: 10,
  152. total: 0,
  153. showStatus: 0
  154. }
  155. ],
  156. date: ['日', '一', '二', '三', '四', '五', '六'],
  157. date_num: [20, 21, 22, 23, 24, 25, 26],
  158. list1: [],
  159. list2: [],
  160. list3: [],
  161. windowHeight: 0
  162. };
  163. },
  164. onLoad() {},
  165. mounted() {
  166. this.windowHeight = uni.getSystemInfoSync().windowHeight;
  167. this.initList();
  168. this.advertisingList();
  169. // d是当前星期一的日期对象
  170. var d=this.getMonDate();
  171. var arr=[];
  172. for(var i=0; i<7; i++)
  173. {
  174. arr.push(d.getFullYear()+'年'+(d.getMonth()+1)+'月'+d.getDate()+'日 ('+getDayName(d.getDay())+')');
  175. d.setDate(d.getDate()+1);
  176. }
  177. },
  178. methods: {
  179. getMonDate()
  180. {
  181. var d=new Date(),
  182. day=d.getDay(),
  183. date=d.getDate();
  184. if(day==1)
  185. return d;
  186. if(day==0)
  187. d.setDate(date-6);
  188. else
  189. d.setDate(date-day+1);
  190. return d;
  191. },
  192. getDayName(day)
  193. {
  194. var day=parseInt(day);
  195. if(isNaN(day) || day<0 || day>6)
  196. return false;
  197. var weekday=["星期天","星期一","星期二","星期三","星期四","星期五","星期六"];
  198. return weekday[day];
  199. },
  200. swiperClick(index){
  201. let item = this.list[index]
  202. uni.navigateTo({
  203. url: item.jumpUrl
  204. });
  205. },
  206. advertisingList(){
  207. let self = this
  208. this.$api.advertisingList().then(res => {
  209. let index;
  210. for (index in res.data.rows ) {
  211. res.data.rows[index].image = res.data.rows[index].adverUrl
  212. }
  213. self.list = res.data.rows
  214. });
  215. },
  216. initList() {
  217. this.courseList();
  218. this.bankList();
  219. this.noteList();
  220. },
  221. scroll(e) {},
  222. scrollTolower() {
  223. if (this.current == 0) {
  224. if (this.list1.length < this.paramList[0].total) {
  225. this.paramList[0].pageNum++;
  226. this.courseList();
  227. }
  228. }
  229. if (this.current == 1) {
  230. if (this.list1.length < this.paramList[1].total) {
  231. this.paramList[1].pageNum++;
  232. this.bankList();
  233. }
  234. }
  235. if (this.current == 2) {
  236. if (this.list1.length < this.paramList[2].total) {
  237. this.paramList[2].pageNum++;
  238. this.noteList();
  239. }
  240. }
  241. },
  242. sectionChange(index) {
  243. this.current = index;
  244. },
  245. //课程
  246. courseList() {
  247. var self = this;
  248. var param = this.paramList[0];
  249. this.$api.courselist(param).then(res => {
  250. self.paramList[0].total = res.data.total;
  251. self.list1.push.apply(self.list1, res.data.rows);
  252. if (self.list1.length === res.data.total) {
  253. self.paramList[0].showStatus = true;
  254. }
  255. });
  256. },
  257. //题库
  258. bankList() {
  259. var self = this;
  260. var param = this.paramList[1];
  261. this.$api.banklist(param).then(res => {
  262. self.paramList[1].total = res.data.total;
  263. self.list2.push.apply(self.list2, res.data.rows);
  264. if (self.list2.length === res.data.total) {
  265. self.paramList[1].showStatus = true;
  266. }
  267. });
  268. },
  269. //考试重点
  270. noteList() {
  271. var self = this;
  272. var param = this.paramList[2];
  273. this.$api.notelist(param).then(res => {
  274. self.paramList[2].total = res.data.total;
  275. self.list3.push.apply(self.list3, res.data.rows);
  276. if (self.list3.length === res.data.total) {
  277. self.paramList[2].showStatus = true;
  278. }
  279. });
  280. },
  281. jumpDetail(item) {
  282. if (this.current == 0) {
  283. this.$navTo.togo('/pages2/course/detail', {
  284. id: item.courseId
  285. });
  286. return;
  287. }
  288. if (this.current == 1) {
  289. this.$navTo.togo('/pages2/bank/detail', {
  290. id: item.bankId
  291. });
  292. return;
  293. }
  294. if (this.current == 2) {
  295. this.$navTo.togo('/pages2/course/keynote', {
  296. id: item.fileId
  297. });
  298. return;
  299. }
  300. },
  301. jumpPlan() {
  302. if(!this.$method.isLogin()){
  303. this.$navTo.togo('/pages/login/login');
  304. }else{
  305. this.$navTo.togo('/pages2/plan/detail', {});
  306. }
  307. },
  308. jumpSearch() {
  309. this.$navTo.togo('/pages2/index/search', {});
  310. }
  311. }
  312. };
  313. </script>
  314. <style scoped>
  315. .search {
  316. width: 40rpx;
  317. height: 40rpx;
  318. margin-left: 30rpx;
  319. }
  320. .slot-wrap {
  321. display: flex;
  322. align-items: center;
  323. }
  324. .popup_t1 {
  325. height: 29rpx;
  326. font-size: 30rpx;
  327. font-family: PingFang SC;
  328. font-weight: bold;
  329. color: #131b31;
  330. margin: 100rpx;
  331. }
  332. .price {
  333. font-size: 20rpx;
  334. font-family: PingFang SC;
  335. font-weight: bold;
  336. color: #ff0000;
  337. margin-top: 8rpx;
  338. }
  339. .old_price {
  340. font-size: 24rpx;
  341. font-family: PingFang SC;
  342. font-weight: bold;
  343. text-decoration: line-through;
  344. color: #999999;
  345. margin-top: 8rpx;
  346. }
  347. .list_title {
  348. font-size: 24rpx;
  349. font-family: PingFang SC;
  350. font-weight: bold;
  351. color: #2f4379;
  352. }
  353. .list_content {
  354. width: 656rpx;
  355. height: 134rpx;
  356. background: #ffffff;
  357. box-shadow: 0rpx 0rpx 16rpx 4rpx rgba(47, 67, 121, 0.1);
  358. border-radius: 24rpx;
  359. position: absolute;
  360. top: 20rpx;
  361. left: 20rpx;
  362. }
  363. .list_box {
  364. position: relative;
  365. width: 100%;
  366. margin-top: 30rpx;
  367. }
  368. .list_img {
  369. width: 278rpx;
  370. height: 134rpx;
  371. z-index: 100;
  372. position: relative;
  373. }
  374. .course_title {
  375. color: #2f4379;
  376. box-shadow: 0rpx 0rpx 9rpx 1rpx rgba(47, 67, 121, 0.1);
  377. border-radius: 28rpx;
  378. width: 100%;
  379. height: 48rpx;
  380. line-height: 48rpx;
  381. }
  382. .arr-icon {
  383. width: 40rpx;
  384. height: 40rpx;
  385. }
  386. .wrap {
  387. padding: 24rpx;
  388. }
  389. .u-row {
  390. margin: 40rpx 0;
  391. }
  392. .date_num {
  393. width: 14%;
  394. text-align: center;
  395. color: #34c759;
  396. }
  397. .card_date {
  398. width: 14%;
  399. text-align: center;
  400. color: #7f8caf;
  401. }
  402. page {
  403. background: #ffffff;
  404. font-size: 28rpx;
  405. }
  406. .calendar_card {
  407. width: 100%;
  408. height: 300rpx;
  409. background: #ffffff;
  410. box-shadow: 0rpx 0rpx 16rpx 4rpx rgba(47, 67, 121, 0.1);
  411. border-radius: 22rpx;
  412. margin-top: 25rpx;
  413. }
  414. .box {
  415. margin: 30rpx;
  416. }
  417. .my_swiper {
  418. box-shadow: 0rpx 20rpx 16rpx 4rpx rgba(47, 67, 121, 0.08);
  419. border-radius: 25rpx;
  420. }
  421. .calendar_card .card_box {
  422. height: 60rpx;
  423. line-height: 60rpx;
  424. margin-left: 40rpx;
  425. }
  426. .calendar_card .t1 {
  427. color: #7f8caf;
  428. font-size: 24rpx;
  429. }
  430. .calendar_card .t2 {
  431. font-size: 24rpx;
  432. font-family: PingFang SC;
  433. font-weight: bold;
  434. color: #32467b;
  435. margin: 0 10rpx;
  436. }
  437. .calendar_card .t3 {
  438. font-size: 30rpx;
  439. font-weight: bold;
  440. color: #32467b;
  441. text-shadow: 0rpx 3rpx 3rpx rgba(0, 0, 0, 0.2);
  442. margin: 0 10rpx;
  443. }
  444. .img_more {
  445. width: 26rpx;
  446. height: 26rpx;
  447. }
  448. </style>