resource.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  1. <template>
  2. <view class="resource">
  3. <statusBar :item="navBarData"></statusBar>
  4. <view class="search">
  5. <uni-search-bar v-model="searchText" bgColor="#f0f2f5" class="btntop" placeholder="搜索" cancelButton="none"
  6. clearButton="none"></uni-search-bar>
  7. </view>
  8. <view class="top">
  9. <view class="left" @click="phoneLogin" :class="current == 0 ? info1 : info2">
  10. <text class="">资源库</text>
  11. <view v-if="current == 0" class="yun">
  12. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//yym/Ellipse 10.png"
  13. mode="aspectFill"></image>
  14. </view>
  15. </view>
  16. <view class="right" @click="accountLogin" :class="current == 1 ? info1 : info2">
  17. <text class="">精品慕课</text>
  18. <view v-if="current == 1" class="yun">
  19. <image src="https://teacherapi.cocorobo.cn/teaching-file/static//yym/Ellipse 10.png"
  20. mode="aspectFill"></image>
  21. </view>
  22. </view>
  23. </view>
  24. <swiper class="scroll-view-height" :style="{ height: swiper + 'px' }" @change="swipeIndex" :current="current"
  25. :duration="300">
  26. <swiper-item>
  27. <scroll-view scroll-y="true" :style="{ height: swiper + 'px' }">
  28. <view class="contBox">
  29. <view class="cont" @click="gotozyk" v-for="(item, index) in filteredClassList" :index="index"
  30. :key="index" :data-reId="item.goto">
  31. <image class="image" :src="item.url" mode="aspectFill" />
  32. <view class="tit btn-font">{{ item.className }}</view>
  33. <view class="teacher fz-font">主讲教师:{{ item.th_name }}</view>
  34. </view>
  35. </view>
  36. </scroll-view>
  37. </swiper-item>
  38. <swiper-item>
  39. <scroll-view scroll-y="true" :style="{ height: swiper + 'px' }">
  40. <view class="contBox">
  41. <view class="cont" @click="gotoWeb" v-for="(item, index) in filteredClassList2" :index="index"
  42. :key="index" :data-kid="item.goto">
  43. <image class="image" :src="item.url" mode="aspectFill" />
  44. <view class="tit btn-font">{{ item.className }}</view>
  45. <view class="teacher fz-font">主讲教师:{{ item.th_name }}</view>
  46. </view>
  47. </view>
  48. </scroll-view>
  49. </swiper-item>
  50. </swiper>
  51. </view>
  52. </template>
  53. <script>
  54. export default {
  55. data() {
  56. return {
  57. navBarData: {
  58. title: "资源库",
  59. btn: 0,
  60. },
  61. current: 0, //登录方式切换
  62. info1: "info1", //类名
  63. info2: "info2",
  64. swiper: 0,
  65. searchText: "", // 搜索文本
  66. classList: [{
  67. url: "https://teacherapi.cocorobo.cn/teaching-file/static//pubic/img5.jpg",
  68. className: "创新思维",
  69. goto: "https://zyk.icve.com.cn/courseDetailed?id=efajaxyn4p1fahmj-32xng",
  70. th_name: "吴伟",
  71. },
  72. {
  73. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/sc.jpg",
  74. className: "商机识别与创业营销 ",
  75. goto: "https://zyk.icve.com.cn/courseDetailed?id=bxmpaiwpzrjixvfpvdzj7w ",
  76. th_name: "明照凤 ",
  77. },
  78. {
  79. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/sg.jpg",
  80. className: "双创生态圈构建 ",
  81. goto: "https://zyk.icve.com.cn/courseDetailed?id=ewvaiwparxiamjafg03aa ",
  82. th_name: "徐文泽",
  83. },
  84. {
  85. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/cy.jpg",
  86. className: "创业基础 ",
  87. goto: "https://zyk.icve.com.cn/courseDetailed?id=f-enaxunb7ngggksdm0ivq",
  88. th_name: "杨哲旗",
  89. },
  90. {
  91. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/ks.png",
  92. className: "跨界产品研发实战 ",
  93. goto: "https://zyk.icve.com.cn/courseDetailed?id=fjioasmspopfnyo0l7d2a",
  94. th_name: "王程程",
  95. },
  96. {
  97. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/cs.jpg",
  98. className: "创造性思维与创新方法训练 ",
  99. goto: "https://zyk.icve.com.cn/courseDetailed?id=inanarowyjhlw5vrlnrchw",
  100. th_name: "申珊珊",
  101. },
  102. {
  103. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/hs.jpg",
  104. className: "行业创业实践 ",
  105. goto: "https://zyk.icve.com.cn/courseDetailed?id=jkwpajcprqdgz4dlumimza",
  106. th_name: "陆亚文",
  107. },
  108. {
  109. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/cx.png",
  110. className: "创新方法与训练 ",
  111. goto: "https://zyk.icve.com.cn/courseDetailed?id=klaqaycnir9cklu4y8yaia",
  112. th_name: "张梦龙",
  113. },
  114. ],
  115. classList2: [{
  116. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/ydjk.png",
  117. className: "运动与健康",
  118. goto: "https://www.xuetangx.com/course/HUBU10011000132/16906642?channel=i.area.course_list_all",
  119. th_name: "代方梅 史文文 等",
  120. },
  121. {
  122. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/shyy.png",
  123. className: "生活英语听说",
  124. goto: "https://www.xuetangx.com/course/THU05021000376?channel=i.area.course_list_all",
  125. th_name: "杨芳 张文霞",
  126. },
  127. {
  128. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/yyll.jpg",
  129. className: "科研伦理与学术规范",
  130. goto: "https://www.xuetangx.com/course/BNU03031000037/16905009?channel=i.area.course_list_all",
  131. th_name: "印波",
  132. },
  133. {
  134. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/kylw.png",
  135. className: "如何写好科研论文",
  136. goto: "https://www.xuetangx.com/course/THU04011000365/16906220?channel=i.area.course_list_all",
  137. th_name: "高飞飞 张靖 等",
  138. },
  139. {
  140. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-1.jpg",
  141. className: "中国共产党与中华民族伟大复兴",
  142. goto: "https://www.xuetangx.com/course/zysy06011001641?channel=i.area.course_list_all",
  143. th_name: "杜玉芳"
  144. },
  145. {
  146. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-2.jpg",
  147. className: "大国航母与舰载机",
  148. goto: "https://www.xuetangx.com/course/NAU08091000091/16904996?channel=i.area.course_list_all",
  149. th_name: "岳奎志 郭卫刚 等",
  150. },
  151. {
  152. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-4.jpg",
  153. className: "体育与社会",
  154. goto: "https://www.xuetangx.com/course/Wuhanty04021002450/16906830?channel=i.area.course_list_all",
  155. th_name: "张德胜 李菁 等",
  156. },
  157. {
  158. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-5.png",
  159. className: "公共管理学",
  160. goto: "https://www.xuetangx.com/course/NUDT12041000081?channel=i.area.course_list_all",
  161. th_name: "张学礼",
  162. },
  163. {
  164. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-6.png",
  165. className: "心理学概论",
  166. goto: "https://www.xuetangx.com/course/THU07111000416/16905032?channel=i.area.course_list_all",
  167. th_name: "彭凯平"
  168. },
  169. {
  170. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-7.png",
  171. className: "C++语言程序设计基础",
  172. goto: "https://www.xuetangx.com/course/THU08091000247/16906211?channel=i.area.course_list_all",
  173. th_name: "郑莉 李超 等",
  174. },
  175. {
  176. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-8.png",
  177. className: "《资治通鉴》导读",
  178. goto: "https://www.xuetangx.com/course/THU03011000245/16905905?channel=i.area.course_list_all",
  179. th_name: "张国刚",
  180. },
  181. {
  182. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-9.png",
  183. className: "军事理论",
  184. goto: "https://www.xuetangx.com/course/NDU00001001710?channel=i.area.course_list_all",
  185. th_name: "徐焰杜 文龙 等",
  186. },
  187. {
  188. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-10.png",
  189. className: "数据结构(上)",
  190. goto: "https://www.xuetangx.com/course/THU08091000384/16906679?channel=i.area.course_list_all",
  191. th_name: "邓俊辉",
  192. },
  193. {
  194. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-11.png",
  195. className: "不朽的艺术:走进大师与经典",
  196. goto: "https://www.xuetangx.com/course/THU13011000261/16904949?channel=i.area.course_list_all",
  197. th_name: "肖鹰 孙晶",
  198. },
  199. {
  200. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-12.jpg",
  201. className: "中国近现代史纲要",
  202. goto: "https://www.xuetangx.com/course/THU03051000444/16905083?channel=i.area.course_list_all",
  203. th_name: "翁贺凯",
  204. },
  205. {
  206. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-13.png",
  207. className: "马克思主义基本原理",
  208. goto: "https://www.xuetangx.com/course/THU03051000344/16906535?channel=i.area.course_list_all",
  209. th_name: "刘震 刘恩至 等",
  210. },
  211. {
  212. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-14.png",
  213. className: "数据结构(下)",
  214. goto: "https://www.xuetangx.com/course/THU08091002048/16906478?channel=i.area.course_list_all",
  215. th_name: "邓俊辉"
  216. },
  217. {
  218. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-16.png",
  219. className: "大学生心理健康",
  220. goto: "https://www.xuetangx.com/course/THU07111000285/16905861?channel=i.area.course_list_all",
  221. th_name: "李焰 刘丹 等",
  222. },
  223. {
  224. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-17.png",
  225. className: "财务分析与决策",
  226. goto: "https://www.xuetangx.com/course/THU02031000264?channel=i.area.course_list_all",
  227. th_name: "肖星",
  228. },
  229. {
  230. url: "https://teacherapi.cocorobo.cn/teaching-file/static//img/Cardimg-15.png",
  231. className: "习近平新时代中国特色社会主义思想",
  232. goto: "https://www.xuetangx.com/course/THU03051000744/16905028?channel=i.area.course_list_all",
  233. th_name: "胡鞍钢",
  234. },
  235. ],
  236. };
  237. },
  238. // 模糊搜索
  239. computed: {
  240. filteredClassList() {
  241. const filteredList = this.classList.filter((item) =>
  242. item.className.includes(this.searchText)
  243. );
  244. return this.searchText ? filteredList : this.classList;
  245. },
  246. filteredClassList2() {
  247. const filterdList2 = this.classList2.filter((item) =>
  248. item.className.includes(this.searchText)
  249. );
  250. return this.searchText ? filterdList2 : this.classList2;
  251. },
  252. },
  253. methods: {
  254. gotozyk(e) {
  255. const value = this.$store.state.user.openid;
  256. if (value == '') {
  257. uni.navigateTo({
  258. url: "/pages/login_Wechat/login_Wechat",
  259. });
  260. return
  261. }
  262. let acid = e.currentTarget.dataset.reid
  263. uni.navigateTo({
  264. url: "/pages/skipone/skipone?url=" + encodeURIComponent(acid),
  265. });
  266. // const urls = [
  267. // "https://zyk.icve.com.cn/courseDetailed?id=efajaxyn4p1fahmj-32xng",
  268. // "https://zyk.icve.com.cn/courseDetailed?id=bxmpaiwpzrjixvfpvdzj7w ",
  269. // "https://zyk.icve.com.cn/courseDetailed?id=ewvaiwparxiamjafg03aa ",
  270. // "https://zyk.icve.com.cn/courseDetailed?id=f-enaxunb7ngggksdm0ivq",
  271. // "https://zyk.icve.com.cn/courseDetailed?id=fjioasmspopfnyo0l7d2a",
  272. // "https://zyk.icve.com.cn/courseDetailed?id=inanarowyjhlw5vrlnrchw",
  273. // "https://zyk.icve.com.cn/courseDetailed?id=jkwpajcprqdgz4dlumimza",
  274. // "https://zyk.icve.com.cn/courseDetailed?id=klaqaycnir9cklu4y8yaia"
  275. // ];
  276. },
  277. gotoWeb(e) {
  278. const value = this.$store.state.user.openid;
  279. if (value == '') {
  280. uni.navigateTo({
  281. url: "/pages/login_Wechat/login_Wechat",
  282. });
  283. return
  284. }
  285. // return console.log('aaaaaa', e.currentTarget.dataset);
  286. let acid = e.currentTarget.dataset.kid
  287. uni.navigateTo({
  288. url: "/pages/skipone/skipone?url=" + encodeURIComponent(acid),
  289. });
  290. // if (this.current === 1) {
  291. // const url_header = 'https://www.xuetangx.com/course'
  292. // const urls = [
  293. // "/HUBU10011000132/16906642?channel=i.area.course_list_all",
  294. // "/THU05021000376?channel=i.area.course_list_all",
  295. // "/BNU03031000037/16905009?channel=i.area.course_list_all",
  296. // "/THU04011000365/16906220?channel=i.area.course_list_all",
  297. // "/zysy06011001641?channel=i.area.course_list_all",
  298. // "/NAU08091000091/16904996?channel=i.area.course_list_all",
  299. // "/Wuhanty04021002450/16906830?channel=i.area.course_list_all",
  300. // "/NUDT12041000081?channel=i.area.course_list_all",
  301. // "/THU07111000416/16905032?channel=i.area.course_list_all",
  302. // "/THU08091000247/16906211?channel=i.area.course_list_all",
  303. // "/THU03011000245/16905905?channel=i.area.course_list_all",
  304. // "/NDU00001001710?channel=i.area.course_list_all",
  305. // "/THU08091000384/16906679?channel=i.area.course_list_all",
  306. // "/THU13011000261/16904949?channel=i.area.course_list_all",
  307. // "/THU03051000444/16905083?channel=i.area.course_list_all",
  308. // "/THU03051000344/16906535?channel=i.area.course_list_all",
  309. // "/THU08091002048/16906478?channel=i.area.course_list_all",
  310. // "/THU07111000285/16905861?channel=i.area.course_list_all",
  311. // "/THU02031000264?channel=i.area.course_list_all",
  312. // "/THU03051000744/16905028?channel=i.area.course_list_all"
  313. // ];
  314. // if (index >= 0 && index < urls.length) {
  315. // const url = urls[index];
  316. // uni.navigateTo({
  317. // url: "/pages/skipone/skipone?url=" + url_header + encodeURIComponent(url),
  318. // });
  319. // }
  320. // }
  321. },
  322. toggleActive1() {
  323. this.isActive1 = true;
  324. this.isActive2 = false;
  325. this.tab = true;
  326. },
  327. toggleActive2() {
  328. this.isActive1 = false;
  329. this.isActive2 = true;
  330. this.tab = false;
  331. },
  332. swipeIndex(index) {
  333. this.current = index.detail.current;
  334. },
  335. phoneLogin() {
  336. this.current = 0;
  337. },
  338. accountLogin() {
  339. this.current = 1;
  340. },
  341. },
  342. onLoad() {
  343. if (this.navheight) {
  344. this.swiper = this.screenHeight - this.navheight - 140;
  345. } else {
  346. this.swiper = this.screenHeight - this.customBar - 150;
  347. }
  348. },
  349. };
  350. </script>
  351. <style lang="scss" scoped>
  352. .btntop {
  353. width: 100%;
  354. }
  355. .resource {
  356. .search {
  357. background-color: #ffffff;
  358. position: relative;
  359. display: flex;
  360. width: 750rpx;
  361. height: 88rpx;
  362. justify-content: center;
  363. align-items: center;
  364. // background-color: rebeccapurple;
  365. .inpSer {
  366. width: 690rpx;
  367. height: 65rpx;
  368. margin: auto;
  369. background-color: rgba(240, 242, 245, 1);
  370. border-radius: 5rpx;
  371. color: rgba(0, 0, 0, 0.26);
  372. position: relative;
  373. .inpTxt {
  374. // padding: 0px, 12rpx, 0px, 12rpx;
  375. color: #000;
  376. height: 100%;
  377. width: 100%;
  378. }
  379. input::placeholder {
  380. color: #000;
  381. }
  382. .ico {
  383. position: absolute;
  384. top: 50%;
  385. left: 20rpx;
  386. transform: translate(0, -50%);
  387. display: flex;
  388. align-items: center;
  389. image {
  390. margin-right: 10rpx;
  391. }
  392. }
  393. }
  394. }
  395. .top {
  396. // width: 500rpx;
  397. display: flex;
  398. justify-content: space-between;
  399. margin: auto;
  400. background-color: #ffffff;
  401. padding: 10px 150rpx;
  402. // margin-bottom: 40px;
  403. // font-size: 18px;
  404. // padding-top: 0;
  405. .info1 {
  406. font-weight: bold !important;
  407. position: relative;
  408. color: rgba(0, 0, 0, 0.8);
  409. font-size: 34rpx;
  410. line-height: 48rpx;
  411. width: 136rpx;
  412. height: 48rpx;
  413. text-align: center;
  414. // font-family: PingFang SC;
  415. // font-family: \9ed1\4f53;
  416. .yun {
  417. width: 134rpx;
  418. height: 32rpx;
  419. position: absolute;
  420. left: 0;
  421. bottom: -10rpx;
  422. // transform: translate(-50%,0%);
  423. // box-shadow: 0px 10rpx 30rpx 6rpx #4a97f2;
  424. image {
  425. width: 100%;
  426. height: 100%;
  427. }
  428. }
  429. }
  430. .info2 {
  431. color: rgba(0, 0, 0, 0.6);
  432. font-size: 34rpx;
  433. font-weight: 400;
  434. line-height: 48rpx;
  435. width: 136rpx;
  436. height: 48rpx;
  437. text-align: center;
  438. font-family: 微软雅黑;
  439. }
  440. }
  441. .scroll-view-height {
  442. // background-color: ;
  443. // height: 68vh;
  444. // background-color: red;
  445. // padding-bottom: 50px;
  446. .contBox {
  447. width: 100%;
  448. padding: 10px 30rpx;
  449. // height: 100%;
  450. display: flex;
  451. flex-wrap: wrap;
  452. justify-content: space-between;
  453. // background-color: greenyellow;
  454. margin-bottom: 50px;
  455. .cont {
  456. background-color: #ffffff;
  457. width: 332rpx;
  458. padding: 20rpx 15rpx;
  459. border-radius: 10px;
  460. margin-bottom: 20rpx;
  461. image {
  462. width: 300rpx;
  463. height: 170rpx;
  464. border-radius: 10rpx;
  465. }
  466. .tit {
  467. width: 257rpx;
  468. margin: 10rpx 0;
  469. // height: 80rpx;
  470. font-weight: bold;
  471. white-space: normal;
  472. display: -webkit-box;
  473. word-break: break-all;
  474. text-overflow: ellipsis;
  475. overflow: hidden;
  476. -webkit-box-orient: vertical;
  477. -webkit-line-clamp: 2;
  478. /*设置 需要显示的行数*/
  479. }
  480. .teacher {
  481. color: #999999;
  482. }
  483. }
  484. }
  485. }
  486. }
  487. </style>