This commit is contained in:
francis_fh
2026-01-27 11:04:32 +08:00
5 changed files with 82 additions and 46 deletions

View File

@@ -1,11 +1,11 @@
<!-- <!--
* @Date: 2025-10-16 15:15:47 * @Date: 2025-10-16 15:15:47
* @LastEditors: lip * @LastEditors: shirlwang
* @LastEditTime: 2026-01-14 21:33:18 * @LastEditTime: 2026-01-27 09:30:18
--> -->
<template> <template>
<!-- @scroll="handleScroll" @scrolltolower="scrollBottom" --> <!-- @scroll="handleScroll" @scrolltolower="scrollBottom" -->
<scroll-view :scroll-y="true" class="container" style="background-image: url('../../../packageRc/static/pageBg.png');"> <scroll-view :scroll-y="true" class="container" style="background-image: url('../../../packageRc/static/pageBgIndex.png');">
<view style="padding: 40rpx 28rpx;"> <view style="padding: 40rpx 28rpx;">
<!-- #ifdef MP-WEIXIN --> <!-- #ifdef MP-WEIXIN -->
<view class="kinggang"> <view class="kinggang">
@@ -31,54 +31,69 @@
</view> </view>
</view> </view>
<!-- #endif --> <!-- #endif -->
<view class="tabs"> <view class="showtab">
<view class="tab" :class="{active: pageState.type == ''}" @click="changeJobType('')">岗位列表</view> <view class="tabItem" @click="changeType(1)">
<view class="tab" :class="{active: pageState.type == 2}" @click="changeJobType(2)">实习实训</view> <image src="/packageRc/static/gw.png"/>
<view class="tab" :class="{active: pageState.type == 3}" @click="changeJobType(3)">社区实践</view> <image v-show="tabType == 1" class="activeImg" src="/packageRc/static/activeTangle.png"/>
</view>
<view class="titles">
<view class="title-item" :class="{active: activeTitle == 1}" @click="activeTitle = 1,getJobRecommed()"><view>推荐岗位</view></view>
<view class="title-item" :class="{active: activeTitle == 2}" @click="activeTitle = 2,getJobList()"><view>热门岗位</view></view>
</view>
<view v-for="(item, index) in jobList" :key="index" @click="nextDetail(item)" class="job-list">
<view class="top-line">
<view class="salary">{{item.minSalary}}-{{item.maxSalary}}/</view>
<view class="time"><uni-icons color="#A2A2A2" type="info" size="12"></uni-icons>发布日期{{ item.postingDate }}</view>
</view> </view>
<view class="title">{{ item.jobTitle }}</view> <view class="tabItem" @click="changeType(2)">
<view class="infos"> <image src="/packageRc/static/zc.png"/>
<view> <image v-show="tabType == 2" class="activeImg" src="/packageRc/static/activeTangle.png"/>
<dict-Label dictType="education" :value="item.education"></dict-Label> </view>
</view>
<template v-if="tabType == 1">
<view class="tabs">
<view class="tab" :class="{active: pageState.type == ''}" @click="changeJobType('')">岗位列表</view>
<view class="tab" :class="{active: pageState.type == 2}" @click="changeJobType(2)">实习实训</view>
<view class="tab" :class="{active: pageState.type == 3}" @click="changeJobType(3)">社区实践</view>
</view>
<view class="titles">
<view class="title-item" :class="{active: activeTitle == 1}" @click="activeTitle = 1,getJobRecommed()"><view>推荐岗位</view></view>
<view class="title-item" :class="{active: activeTitle == 2}" @click="activeTitle = 2,getJobList()"><view>热门岗位</view></view>
</view>
<view v-for="(item, index) in jobList" :key="index" @click="nextDetail(item)" class="job-list">
<view class="top-line">
<view class="salary">{{item.minSalary}}-{{item.maxSalary}}/</view>
<view class="time"><uni-icons color="#A2A2A2" type="info" size="12"></uni-icons>发布日期{{ item.postingDate }}</view>
</view> </view>
<view> <view class="title">{{ item.jobTitle }}</view>
<dict-Label dictType="experience" :value="item.experience"></dict-Label> <view class="infos">
<view>
<dict-Label dictType="education" :value="item.education"></dict-Label>
</view>
<view>
<dict-Label dictType="experience" :value="item.experience"></dict-Label>
</view>
<view>{{ item.jobLocation }}</view>
</view>
<view class="bottom-line">
<view><uni-icons color="#A2A2A2" type="person" size="12"></uni-icons>{{item.vacancies}}</view>
<view>{{ item.companyName }}</view>
</view> </view>
<view>{{ item.jobLocation }}</view>
</view> </view>
<view class="bottom-line">
<view><uni-icons color="#A2A2A2" type="person" size="12"></uni-icons>{{item.vacancies}}</view> <view class="view-more-btn" @click="viewMore">查看更多内容</view>
<view>{{ item.companyName }}</view>
</template>
<template v-else>
<view class="titles" style="justify-content: space-between;">
<view class="title-item active"><view>政策专区</view></view>
<view @click="toPolicyList">{{'查看更多 >'}}</view>
</view> </view>
</view> <view v-for="(item, index) in policyList" :key="index" class="job-list" @click="toPolicyDetail(item)">
<view class="sign">推荐</view>
<view class="view-more-btn" @click="viewMore">查看更多内容</view> <view class="title">
<view class="titles" style="justify-content: space-between;"> <image src="../../../packageRc/static/zcLeft.png"/>
<view class="title-item active"><view>政策专区</view></view> {{item.zcmc}}</view>
<view @click="toPolicyList">{{'查看更多 >'}}</view> <view class="infos">
</view> <view v-if="item.zcLevel">{{item.zcLevel}}</view>
<view v-for="(item, index) in policyList" :key="index" class="job-list" @click="toPolicyDetail(item)"> <view v-if="item.sourceUnit">{{item.sourceUnit}}</view>
<view class="sign">推荐</view> </view>
<view class="title"> <view class="bottom-line">
<image src="../../../packageRc/static/zcLeft.png"/> <view><uni-icons color="#A2A2A2" type="info" size="12"></uni-icons>发布日期:{{item.createTime}}</view>
{{item.zcmc}}</view> </view>
<view class="infos">
<view v-if="item.zcLevel">{{item.zcLevel}}</view>
<view v-if="item.sourceUnit">{{item.sourceUnit}}</view>
</view> </view>
<view class="bottom-line"> </template>
<view><uni-icons color="#A2A2A2" type="info" size="12"></uni-icons>发布日期:{{item.createTime}}</view>
</view>
</view>
</view> </view>
</scroll-view> </scroll-view>
</template> </template>
@@ -94,7 +109,10 @@ function getPolicy() {
policyList.value = res.rows policyList.value = res.rows
}) })
} }
let tabType = ref(1)
function changeType(type) {
tabType.value = type
}
function toPolicyList() { function toPolicyList() {
navTo(`/packageRc/pages/policy/policyList?zclx=1`) navTo(`/packageRc/pages/policy/policyList?zclx=1`)
} }
@@ -377,4 +395,22 @@ view{box-sizing: border-box;display: block;}
margin: 0 auto; margin: 0 auto;
margin-bottom: 20rpx; margin-bottom: 20rpx;
} }
.showtab{
display: flex;
justify-content: space-between;
margin-bottom: 40rpx;
.tabItem{
position: relative;
width: calc(50% - 8rpx);
height: 144rpx;
}
.activeImg{
position: absolute;
width: 143rpx;
height: 18rpx;
bottom: -24rpx;
right: 50%;
transform: translateX(50%);
}
}
</style> </style>

Binary file not shown.

After

Width:  |  Height:  |  Size: 734 B

BIN
packageRc/static/gw.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

BIN
packageRc/static/zc.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB