首页UI微调

This commit is contained in:
xuxin
2026-06-03 12:12:59 +08:00
parent e6ae57e5fd
commit 0fcc19f3f8
2 changed files with 34 additions and 23 deletions
+20 -15
View File
@@ -24,7 +24,7 @@
// 导航内容容器 — 居中 12rem 宽 // 导航内容容器 — 居中 12rem 宽
&__inner { &__inner {
width: 12rem; width: 12.40rem;
margin: 0 auto; margin: 0 auto;
height: 0.72rem; height: 0.72rem;
padding: 0.2rem; padding: 0.2rem;
@@ -454,7 +454,7 @@
box-shadow: 0 10px 40px rgba(82, 202, 209, 0.12); box-shadow: 0 10px 40px rgba(82, 202, 209, 0.12);
backdrop-filter: blur(100px); backdrop-filter: blur(100px);
border-radius: 0.4rem; border-radius: 0.4rem;
padding: 0.64rem; padding: 0.64rem 0;
} }
// 岗位数量统计 — 横向排列 // 岗位数量统计 — 横向排列
@@ -465,18 +465,16 @@
margin-bottom: 0.6rem; margin-bottom: 0.6rem;
} }
// 岗位滚动卡片容器 // 岗位滚动卡片容器 — 无缝轮播
&__scroll { &__scroll {
overflow: hidden; overflow: hidden;
>div{
.ticker-track {
display: flex; display: flex;
gap: 0.16rem; gap: 0.16rem;
overflow-x: auto; width: max-content;
padding-bottom: 0.1rem; animation: ticker-scroll 20s linear infinite;
&::-webkit-scrollbar { display: none; }
margin-left: -1.2rem;
} }
} }
} }
@@ -484,7 +482,7 @@
.showcase-stat { .showcase-stat {
text-align: center; text-align: center;
&__num { &__num {
font-size: 0.6rem; font-size: 0.48rem;
line-height: 0.6rem; line-height: 0.6rem;
font-weight: 900; font-weight: 900;
color: #1d1d1d; color: #1d1d1d;
@@ -608,6 +606,12 @@
} }
} }
// 无缝轮播关键帧 — 滚动半程(第一组内容宽度)
@keyframes ticker-scroll {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
// ---- 功能1:匹配卡片 ---- // ---- 功能1:匹配卡片 ----
.feature-match-card { .feature-match-card {
background: rgba(255, 255, 255, 0.9); background: rgba(255, 255, 255, 0.9);
@@ -1260,7 +1264,7 @@
// ==================== 岗位搜索入口 ==================== // ==================== 岗位搜索入口 ====================
.home-job-search { .home-job-search {
padding: 0.8rem 0; padding-bottom: 0.8rem;
// 内容容器 // 内容容器
&__inner { &__inner {
@@ -1272,14 +1276,14 @@
line-height: 0.36rem; line-height: 0.36rem;
font-weight: 600; font-weight: 600;
text-align: center; text-align: center;
margin-bottom: 0.4rem; margin-bottom: 0.6rem;
} }
} }
// 筛选条件横向排列 // 筛选条件横向排列
&__filters { &__filters {
display: flex; display: flex;
gap: 0.24rem; gap: 0.60rem;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
} }
@@ -1308,7 +1312,8 @@
// 搜索按钮 // 搜索按钮
.filter-btn { .filter-btn {
height: 0.48rem; width: 1.84rem;
height: 0.56rem;
padding: 0 0.4rem; padding: 0 0.4rem;
border-radius: 0.16rem; border-radius: 0.16rem;
background: #111; background: #111;
@@ -1431,7 +1436,7 @@
// ==================== 底部 CTA 行动号召 ==================== // ==================== 底部 CTA 行动号召 ====================
.home-cta { .home-cta {
padding: 0 0 1.2rem; padding: 0 0 1.0rem;
width: 100%; width: 100%;
// CTA 内容区 // CTA 内容区
+14 -8
View File
@@ -6,7 +6,7 @@
<div class="home-hero__orb home-hero__orb--top"></div> <div class="home-hero__orb home-hero__orb--top"></div>
<div class="home-hero__orb home-hero__orb--bottom"></div> <div class="home-hero__orb home-hero__orb--bottom"></div>
<!-- 顶部导航栏 --> <!-- 顶部导航栏 -->
<header class="home-nav mt32"> <header class="home-nav mt0">
<div class="home-nav__inner" :class="{ 'home-nav__inner--scorlled': isScrolled }"> <div class="home-nav__inner" :class="{ 'home-nav__inner--scorlled': isScrolled }">
<div class="home-nav__logo"> <div class="home-nav__logo">
<!-- 导航栏Logo图片 --> <!-- 导航栏Logo图片 -->
@@ -82,17 +82,22 @@
<div class="home-jobs-showcase__box"> <div class="home-jobs-showcase__box">
<div class="home-jobs-showcase__stats"> <div class="home-jobs-showcase__stats">
<div class="showcase-stat"> <div class="showcase-stat">
<div class="showcase-stat__num"><span class="accent">40</span><span class="accent"></span>+</div> <div class="showcase-stat__num"><span><span class="accent">40</span><span class="accent"></span></span><span class="fs32">+</span></div>
<div class="showcase-stat__label">岗位总数</div> <div class="showcase-stat__label">岗位总数</div>
</div> </div>
<div class="showcase-stat"> <div class="showcase-stat">
<div class="showcase-stat__num"><span class="accent">{{ dailyJobCount }}</span>个岗位</div> <div class="showcase-stat__num"><span class="accent">{{ dailyJobCount }}</span><span class="fs32"></span></div>
<div class="showcase-stat__label">今日更新</div> <div class="showcase-stat__label">今日更新</div>
</div> </div>
</div> </div>
<div class="home-jobs-showcase__scroll"> <div class="home-jobs-showcase__scroll">
<div> <!-- 无缝轮播两组相同内容拼接动画滚完第一组后无缝衔接 -->
<div class="job-ticker" v-for="(job, i) in tickerJobs" :key="i"> <div class="ticker-track">
<div class="job-ticker" v-for="(job, i) in tickerJobs" :key="'a' + i">
<span class="job-ticker__company">{{ job.company }}·{{ job.time }}</span>
<span class="job-ticker__title">{{ job.title }}</span>
</div>
<div class="job-ticker" v-for="(job, i) in tickerJobs" :key="'b' + i">
<span class="job-ticker__company">{{ job.company }}·{{ job.time }}</span> <span class="job-ticker__company">{{ job.company }}·{{ job.time }}</span>
<span class="job-ticker__title">{{ job.title }}</span> <span class="job-ticker__title">{{ job.title }}</span>
</div> </div>
@@ -222,7 +227,7 @@
<div class="home-feature__inner"> <div class="home-feature__inner">
<div class="home-feature__text"> <div class="home-feature__text">
<h2>名企内推<br/>人脉直通</h2> <h2>名企内推<br/>人脉直通</h2>
<p>时获取名企最新内推信息自动填写网申内推<br/>简历更快到达HR</p> <p>实时获取名企最新内推信息自动填写网申内推<br/>简历更快到达HR</p>
<button class="home-feature__btn" @click="router.push('/jobs')"> <button class="home-feature__btn" @click="router.push('/jobs')">
<img class="w20 h20" src="@/assets/images/home/blue-horn-icon-01.png" alt=""> <img class="w20 h20" src="@/assets/images/home/blue-horn-icon-01.png" alt="">
<span>立即投递</span> <span>立即投递</span>
@@ -556,8 +561,9 @@ const homeCategoryIds = computed<number[]>(() => store.state.jobIntention.catego
/** 选择器触发按钮样式 — 匹配首页 .filter-select 的外观 */ /** 选择器触发按钮样式 — 匹配首页 .filter-select 的外观 */
const filterTriggerStyle = { const filterTriggerStyle = {
width: '2.35rem', width: '2.80rem',
height: '0.48rem', 'max-width': 'none',
height: '0.56rem',
'border-radius': '0.16rem', 'border-radius': '0.16rem',
border: '1px solid #e5e7eb', border: '1px solid #e5e7eb',
padding: '0 0.2rem', padding: '0 0.2rem',