index.vue 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <template>
  2. <view class="index">
  3. <!-- <view class="index-head"></view> -->
  4. <view class="index-header">
  5. <view class="index-header-container">
  6. <view class="index-header-left"></view>
  7. <view class="index-header-right"></view>
  8. <view class="index-header-top">
  9. <u-search placeholder="请输入您关键词" v-model="headerTopKeyword" :show-action="false" class="header-top-usearch"></u-search>
  10. <view class="header-top-notice" @tap="openPage('pages/notification/notification')" >
  11. <u-icon name="bell" color="#FFFFFF" size="48"></u-icon>
  12. <u-badge size="mini" type="error" count="7" :absolute="false" class="header-top-notice-badge"></u-badge>
  13. </view>
  14. <view class="header-top-scan">
  15. <u-icon name="scan" color="#FFFFFF" size="48" class="header-scan-icon"></u-icon>
  16. </view>
  17. </view>
  18. <view class="index-header-banner">
  19. <u-swiper
  20. :list="bannerList"
  21. name="bannerUrl"
  22. border-radius="0"
  23. mode="round"
  24. height="440"
  25. img-mode="scaleToFill"
  26. @click="swiperClick"
  27. ></u-swiper>
  28. </view>
  29. </view>
  30. </view>
  31. <view class="service">
  32. <view class="service-body u-flex u-flex-wrap u-row-left">
  33. <!-- <view class="service-item" @click="openPage('pages/policyNews/policyNews')"> -->
  34. <view class="service-item" @click="openPage('pages/policyInfo/policyInfo')">
  35. <image class="service-item-img" src="../../static/img/index-service-01.png" mode="aspectFill"></image>
  36. <view class="service-item-text">政策资讯</view>
  37. </view>
  38. <view class="service-item" @click="openPage('pages/recruitment/recruitment')" >
  39. <image class="service-item-img" src="../../static/img/index-service-02.png" mode="aspectFill"></image>
  40. <view class="service-item-text">招聘就业</view>
  41. </view>
  42. <view class="service-item" @click="openPage('pages/cooperativeEnterprise/cooperativeEnterprise')" >
  43. <image class="service-item-img" src="../../static/img/index-service-03.png" mode="aspectFill"></image>
  44. <view class="service-item-text">合作企业</view>
  45. </view>
  46. <view class="service-item" @click="openPage('pages/schools/schools')" >
  47. <image class="service-item-img" src="../../static/img/index-service-04.png" mode="aspectFill"></image>
  48. <view class="service-item-text">合作院校</view>
  49. </view>
  50. <view class="service-item" @click="openPage('pages/skillsTraining/skillsTraining')" >
  51. <image class="service-item-img" src="../../static/img/index-service-05.png" mode="aspectFill"></image>
  52. <view class="service-item-text">技能培训</view>
  53. </view>
  54. <view class="service-item" @click="openPage('pages/basicTraining/basicTraining')" >
  55. <image class="service-item-img" src="../../static/img/index-service-06.png" mode="aspectFill"></image>
  56. <view class="service-item-text">适应性培训</view>
  57. </view>
  58. <view class="service-item" @click="openPage('pages/upgrade/upgrade')" >
  59. <image class="service-item-img" src="../../static/img/index-service-07.png" mode="aspectFill"></image>
  60. <view class="service-item-text">学历提升</view>
  61. </view>
  62. <view class="service-item" @click="openPage('pages/inbuild/inbuild','创业指引')" >
  63. <image class="service-item-img" src="../../static/img/index-service-08.png" mode="aspectFill"></image>
  64. <view class="service-item-text">创业指导</view>
  65. </view>
  66. </view>
  67. </view>
  68. <view class="news">
  69. <u-card class="news-list"
  70. :body-style="{'padding-top':0}"
  71. :border="false"
  72. :foot-border-top="false"
  73. :head-border-bottom="false"
  74. :full="true"
  75. :border-radius="10"
  76. margin="0"
  77. >
  78. <view class="news-list-head" slot="head">
  79. <view class="news-list-head-item">
  80. <view class="card-head-title">新闻动态</view>
  81. <view @click="openPage('/pages/newsInformation/newsInformation')">更多<u-icon name="arrow-right" color="#A3A3A3"></u-icon></view>
  82. </view>
  83. </view>
  84. <view class="news-list-body" slot="body">
  85. <u-nodata notice="暂无新闻" v-if="newsList.length==0"></u-nodata>
  86. <view
  87. v-for="(item,index) in newsList"
  88. @click="$u.route('/pages/newsDetails/newsDetails',{artId:item.artId})"
  89. :key="item.artId"
  90. class="news-list-body-item u-body-item u-flex u-border-bottom u-col-between u-row-between"
  91. >
  92. <view class="news-text">
  93. <view class="news-text-title u-body-item-title u-line-2">{{item.artTitle}}</view>
  94. <view class="news-text-foot foot u-flex u-flex-wrap">
  95. <view>{{item.artCategoryName}}</view>
  96. <view>{{$u.timeFormat(item.createTime.replace(/-/g, '/'), 'mm-dd hh:MM')}}</view>
  97. </view>
  98. </view>
  99. <image :src="item.artImage" mode="aspectFill"></image>
  100. </view>
  101. </view>
  102. </u-card>
  103. </view>
  104. <!-- ########################## -- 底部导航栏 -- ################################ -->
  105. <u-tabbar
  106. :list="tabbarConfig.tabbarList"
  107. :height="tabbarConfig.height"
  108. :mid-button="tabbarConfig.midButton"
  109. :inactive-color="tabbarConfig.inactiveColor"
  110. :active-color="tabbarConfig.activeColor"
  111. :mid-button-size="tabbarConfig.midButtonSize"
  112. ></u-tabbar>
  113. </view>
  114. </template>
  115. <script>
  116. import tabbarconfig from 'tabbarconfig.js';
  117. export default {
  118. data() {
  119. return {
  120. headerTopKeyword: '',
  121. paginationConfig:{
  122. pageNo: 1,
  123. pageSize: 10
  124. },
  125. bannerList: [],
  126. newsList:[],
  127. noticeList:['贵州轮胎股份有限公司对您感兴趣,为您提供了职位。','您有一个面试邀请'],
  128. tabbarConfig: tabbarconfig
  129. }
  130. },
  131. onLoad() {
  132. // console.log(this.$u.config.v);
  133. },
  134. onShow() {
  135. this.getBannerList();
  136. this.getNewsList();
  137. },
  138. methods: {
  139. /**
  140. * 打开新页面
  141. * @param {String} path 跳转路径
  142. * */
  143. openPage(path, msg) {
  144. let tempRoute = {
  145. url: path
  146. };
  147. if (msg) {
  148. tempRoute.params = {
  149. msg: msg
  150. };
  151. }
  152. console.log("openPage: ",path);
  153. this.$u.route(tempRoute);
  154. },
  155. getNewsList(){
  156. let params ={
  157. // artCategoryId:2,
  158. pageNum:1,
  159. pageSize:10
  160. }
  161. this.$u.api.getIndexNewsList(params)
  162. .then(res=>{
  163. if(!res) return;
  164. if(res?.code==200){
  165. this.newsList = res.rows;
  166. }else{
  167. uni.showToast({
  168. icon: 'none',
  169. type: 'error',
  170. title:res.msg
  171. })
  172. }
  173. // console.log('newsList',JSON.parse(JSON.stringify(res.rows)));
  174. })
  175. },
  176. getBannerList(){
  177. this.$u.api.getIndexBannerList()
  178. .then(res=>{
  179. if(!res) return;
  180. this.bannerList = res?.data || [];
  181. this.bannerList = [];
  182. this.bannerList.push(
  183. {
  184. bannerUrl: 'https://img.xiaopiu.com/userImages/img3072177d2e954f8.jpg',
  185. content: '<p>代码固定测试内容999998</p>',
  186. id: "999998",
  187. name: "代码固定测试999998"
  188. }
  189. );
  190. this.bannerList.push(
  191. {
  192. bannerUrl: 'https://img.xiaopiu.com/userImages/img14661769874c088.jpg',
  193. content: '<p>代码固定测试内容999999</p>',
  194. id: "999999",
  195. name: "代码固定测试999999"
  196. }
  197. );
  198. })
  199. },
  200. // 轮播图点击
  201. swiperClick (index) {
  202. // console.log('swiperClick',index);
  203. if(this.bannerList[index].jumpUrl){
  204. let url = this.bannerList[index].jumpUrl.split('#')[1];
  205. this.$u.route({
  206. url: url,
  207. });
  208. }else{
  209. this.$u.route({
  210. url: 'pages/bannerDetails/bannerDetails',
  211. params: {
  212. id: this.bannerList[index].id
  213. }
  214. })
  215. }
  216. },
  217. noticeClick(e){
  218. console.log('e',e)
  219. this.openPage('pages/inbuild/inbuild','我的消息')
  220. }
  221. }
  222. }
  223. </script>
  224. <style lang="scss" scoped>
  225. @import "./index.scss";
  226. </style>