feat: 修复wiki样式问题

This commit is contained in:
Blizzard
2026-02-05 10:45:45 +08:00
parent 6ceda92e9d
commit d42471e1d5
17 changed files with 1076 additions and 91 deletions
+65
View File
@@ -0,0 +1,65 @@
// pages/wiki/detail/index.js
import { MOCK_WIKI } from '../../../utils/mockData';
Page({
data: {
plant: null,
activeImageIndex: 0,
swiperList: []
},
onLoad(options) {
if (options.id) {
this.loadPlantDetail(options.id);
}
},
loadPlantDetail(id) {
// Find plant in MOCK_WIKI
const plant = MOCK_WIKI.find(p => p.id === id);
if (plant) {
// Set Page Title
wx.setNavigationBarTitle({
title: plant.name
});
// Prepare swiper list
const swiperList = (plant.images || []).map(img => {
return (img.indexOf('http') === 0 || img.indexOf('wxfile') === 0) ? img : `/assets/${img}`;
});
// Ensure some default values if missing
const enrichedPlant = {
...plant,
light: plant.light || { level: '中等', description: '适合明亮的散射光' },
water: plant.water || { frequency: '每周1-2次', description: '保持土壤微润' },
temperature: plant.temperature || '15-28℃',
humidity: plant.humidity || '50%-70%',
soil: plant.soil || '疏松透气的营养土',
fertilizer: plant.fertilizer || '生长季每月施一次薄肥',
toxicity: plant.toxicity || '无毒',
commonPests: plant.commonPests || ['红蜘蛛'],
careTips: plant.careTips || ['注意通风', '定期清洁叶面']
};
this.setData({
plant: enrichedPlant,
swiperList: swiperList
});
}
},
onSwiperChange(e) {
this.setData({
activeImageIndex: e.detail.current
});
},
onShareAppMessage() {
if (!this.data.plant) return {};
return {
title: `植物百科 - ${this.data.plant.name}`,
path: `/pages/wiki/detail/index?id=${this.data.plant.id}`
};
}
});
+11
View File
@@ -0,0 +1,11 @@
{
"navigationBarTitleText": "百科详情",
"navigationBarBackgroundColor": "#FFFFFF",
"navigationBarTextStyle": "black",
"usingComponents": {
"t-icon": "tdesign-miniprogram/icon/icon",
"t-image": "tdesign-miniprogram/image/image",
"t-swiper": "tdesign-miniprogram/swiper/swiper",
"t-button": "tdesign-miniprogram/button/button"
}
}
+155
View File
@@ -0,0 +1,155 @@
<!--pages/wiki/detail/index.wxml-->
<view class="wiki-detail">
<!-- Header Area -->
<view class="wd-header">
<view class="wd-gallery-container">
<t-swiper
t-class="custom-swiper"
current="{{activeImageIndex}}"
bind:change="onSwiperChange"
height="500rpx"
list="{{swiperList}}"
navigation="{{ { type: '' } }}"
/>
<!-- Gradient applied externally to match plant-detail if needed or just rely on image -->
<view class="wd-gradient-overlay"></view>
</view>
<!-- Custom Indicators -->
<view class="wd-indicators" wx:if="{{swiperList.length > 1}}">
<view
wx:for="{{swiperList}}"
wx:key="index"
class="wd-dot {{index === activeImageIndex ? 'active' : ''}}"
></view>
</view>
<!-- Header Overlay Info -->
<view class="wd-overlay">
<view class="wd-title">
<text class="wd-name">{{plant.name}}</text>
<text class="wd-scientific">{{plant.scientificName}}</text>
</view>
<view class="wd-badges">
<text class="wd-badge">{{plant.family}}</text>
<text class="wd-badge">{{plant.category}}</text>
<text class="wd-badge">难度: {{plant.difficulty || 'Easy'}}</text>
</view>
</view>
</view>
<!-- Content Area -->
<view class="wd-content-wrapper">
<scroll-view class="wd-content" scroll-y enhanced show-scrollbar="{{false}}">
<!-- Description Section -->
<section class="wd-section">
<view class="wd-card">
<text class="wd-text">{{plant.description}}</text>
</view>
</section>
<!-- Basic Info Section -->
<section class="wd-section">
<view class="section-title">
<t-icon name="info-circle" size="40rpx" color="#558B2F" />
<text>基础档案</text>
</view>
<view class="wd-card">
<view class="wd-grid">
<view class="wd-stat-item">
<text class="wd-label">原产地</text>
<text class="wd-value">{{plant.origin}}</text>
</view>
<view class="wd-stat-item">
<text class="wd-label">毒性</text>
<text class="wd-value">{{plant.toxicity}}</text>
</view>
</view>
</view>
</section>
<!-- Care Guide Section -->
<section class="wd-section">
<view class="section-title">
<t-icon name="sprout" size="40rpx" color="#558B2F" />
<text>养护指南</text>
</view>
<view class="wd-card">
<!-- Light -->
<view class="requirement-item">
<view class="req-icon">
<t-icon name="sunny" size="40rpx" color="#558B2F" />
</view>
<view class="req-content">
<text class="req-title">光照 ({{plant.light.level}})</text>
<text class="req-desc">{{plant.light.description}}</text>
</view>
</view>
<!-- Water -->
<view class="requirement-item">
<view class="req-icon">
<t-icon name="water" size="40rpx" color="#558B2F" />
</view>
<view class="req-content">
<text class="req-title">水分 ({{plant.water.frequency}})</text>
<text class="req-desc">{{plant.water.description}}</text>
</view>
</view>
<!-- Environment -->
<view class="requirement-item">
<view class="req-icon">
<t-icon name="temperate" size="40rpx" color="#558B2F" />
</view>
<view class="req-content">
<text class="req-title">环境</text>
<text class="req-desc">温度: {{plant.temperature}}</text>
<text class="req-desc" style="display: block; margin-top: 4rpx;">湿度: {{plant.humidity}}</text>
</view>
</view>
<!-- Soil & Fertilizer -->
<view class="requirement-item">
<view class="req-icon">
<t-icon name="layers" size="40rpx" color="#558B2F" />
</view>
<view class="req-content">
<text class="req-title">土壤与肥料</text>
<text class="req-desc">土: {{plant.soil}}</text>
<text class="req-desc" style="display: block; margin-top: 4rpx;">肥: {{plant.fertilizer}}</text>
</view>
</view>
</view>
</section>
<!-- FAQ Section -->
<section class="wd-section">
<view class="section-title">
<t-icon name="error-circle" size="40rpx" color="#558B2F" />
<text>常见问题</text>
</view>
<view class="wd-card">
<view class="pest-section">
<text class="wd-label" style="display: block; margin-bottom: 16rpx;">易发病虫害</text>
<view class="pest-tags">
<text wx:for="{{plant.commonPests}}" wx:key="*this" class="pest-tag">{{item}}</text>
</view>
</view>
<view class="tips-section">
<text class="wd-label" style="display: block; margin-bottom: 16rpx; margin-top: 32rpx;">专家提示</text>
<view class="care-tips-list">
<view wx:for="{{plant.careTips}}" wx:key="*this" class="tip-item">
<view class="tip-dot"></view>
<text class="tip-text">{{item}}</text>
</view>
</view>
</view>
</view>
</section>
<!-- Bottom Spacer -->
<view style="height: 100rpx;"></view>
</scroll-view>
</view>
</view>
+315
View File
@@ -0,0 +1,315 @@
/* pages/wiki/detail/index.wxss */
.wiki-detail {
height: 100vh;
display: flex;
flex-direction: column;
background: #F9FAFB;
}
/* Page Layout */
page {
height: 100vh;
overflow: hidden;
}
/* Hide Scrollbar Globally */
::-webkit-scrollbar {
display: none !important;
width: 0 !important;
height: 0 !important;
color: transparent !important;
}
scroll-view ::-webkit-scrollbar {
display: none !important;
width: 0 !important;
height: 0 !important;
color: transparent !important;
}
/* Header Area */
.wd-header {
height: 500rpx;
position: relative;
background: #000;
}
/* Content Wrapper handles the flex growth and positioning overlap */
.wd-content-wrapper {
flex: 1;
position: relative;
margin-top: -32rpx;
z-index: 20;
overflow: hidden; /* Ensure scroll-view is contained */
}
/* Content Scroll View fills the wrapper */
.wd-content {
width: 100%;
height: 100%;
}
/* Force override TDesign swiper radius */
.custom-swiper {
border-radius: 0 !important;
overflow: hidden;
--td-swiper-radius: 0px !important;
}
.custom-swiper .t-swiper {
border-radius: 0 !important;
}
t-swiper {
border-radius: 0 !important;
}
.wd-gallery-container {
width: 100%;
height: 100%;
position: relative;
}
.wd-gradient-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
height: 240rpx;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0.7), transparent);
pointer-events: none;
z-index: 10;
}
.wd-indicators {
position: absolute;
bottom: 24rpx;
right: 24rpx;
display: flex;
gap: 12rpx;
z-index: 20;
}
.wd-dot {
width: 12rpx;
height: 12rpx;
border-radius: 50%;
background: rgba(255, 255, 255, 0.4);
transition: all 0.3s;
}
.wd-dot.active {
background: white;
width: 24rpx;
border-radius: 8rpx;
}
.wd-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
padding: 32rpx;
display: flex;
flex-direction: column;
justify-content: flex-start;
pointer-events: none;
z-index: 20;
}
.wd-name {
font-size: 56rpx;
color: #FFFFFF;
font-weight: 800;
margin-bottom: 8rpx;
}
.wd-scientific {
font-size: 32rpx;
color: rgba(255, 255, 255, 0.8);
font-style: italic;
font-family: serif;
margin-bottom: 24rpx;
}
.wd-badges {
display: flex;
gap: 16rpx;
flex-wrap: wrap;
}
.wd-badge {
background: rgba(255, 255, 255, 0.2);
backdrop-filter: blur(4px);
padding: 8rpx 20rpx;
border-radius: 24rpx;
font-size: 24rpx;
color: #FFFFFF;
border: 1px solid rgba(255, 255, 255, 0.2);
}
.wd-section {
margin-bottom: 32rpx;
animation: fadeIn 0.5s ease-out;
padding: 0 32rpx;
}
/* First section specific override: Adjust padding and background to create the seamless rounded look */
.wd-section:first-child {
padding: 0;
margin-bottom: 48rpx;
}
.wd-section:first-child .wd-card {
border-top-left-radius: 40rpx;
border-top-right-radius: 40rpx;
border-bottom-left-radius: 0;
border-bottom-right-radius: 0;
padding: 48rpx 32rpx;
box-shadow: none; /* Seamless blend */
}
@keyframes fadeIn {
from { opacity: 0; transform: translateY(20rpx); }
to { opacity: 1; transform: translateY(0); }
}
.section-title {
display: flex;
align-items: center;
gap: 16rpx;
margin-bottom: 24rpx;
padding-left: 8rpx;
}
.section-title text {
font-size: 34rpx;
font-weight: 700;
color: #111827;
}
.wd-text {
font-size: 30rpx;
line-height: 1.6;
color: #4B5563;
}
.wd-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 32rpx;
}
.wd-stat-item {
display: flex;
flex-direction: column;
gap: 8rpx;
}
.wd-label {
font-size: 24rpx;
color: #9CA3AF;
text-transform: uppercase;
letter-spacing: 1rpx;
}
.wd-value {
font-size: 28rpx;
font-weight: 600;
color: #1F2937;
}
.wd-card {
background: white;
border-radius: 24rpx;
padding: 24rpx;
box-shadow: 0 4rpx 12rpx rgba(0, 0, 0, 0.02);
transition: all 0.3s;
}
/* Requirement Items (Compact) */
.requirement-item {
display: flex;
gap: 24rpx;
margin-bottom: 24rpx;
padding-bottom: 24rpx;
border-bottom: 2rpx solid #F3F4F6;
}
.requirement-item:last-child {
margin-bottom: 0;
padding-bottom: 0;
border-bottom: none;
}
.req-icon {
width: 80rpx;
height: 80rpx;
background: #F1F8E9;
border-radius: 20rpx;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.req-content {
flex: 1;
}
.req-title {
display: block;
font-size: 30rpx;
font-weight: 700;
color: #1F2937;
margin-bottom: 8rpx;
}
.req-desc {
font-size: 26rpx;
color: #6B7280;
line-height: 1.5;
}
/* FAQ / Pests */
.pest-tags {
display: flex;
flex-wrap: wrap;
gap: 16rpx;
}
.pest-tag {
background: #FEF2F2;
color: #DC2626;
padding: 12rpx 24rpx;
border-radius: 16rpx;
font-size: 26rpx;
font-weight: 500;
}
.care-tips-list {
display: flex;
flex-direction: column;
gap: 16rpx;
}
.tip-item {
display: flex;
gap: 16rpx;
align-items: flex-start;
}
.tip-dot {
width: 12rpx;
height: 12rpx;
border-radius: 50%;
background: #558B2F;
margin-top: 14rpx;
flex-shrink: 0;
}
.tip-text {
font-size: 28rpx;
color: #4B5563;
line-height: 1.5;
}