From 196ea43fad22e7d9cbc2e89b74feca95a0f597ba Mon Sep 17 00:00:00 2001 From: haomingming Date: Thu, 21 Aug 2025 09:59:04 +0800 Subject: [PATCH] =?UTF-8?q?=E5=90=88=E5=B9=B6=E7=B2=BE=E5=93=81=E8=AF=BE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- TODO.md | 272 +++ api/api.js | 2 +- api/course_api.js | 42 + generate_placeholder_images.html | 301 ++++ pages.json | 87 +- pages/index/index.vue | 12 +- pages_app/pwdLogin/pwdLogin.vue | 35 +- pages_course/course/course.vue | 1098 +++++++++++ pages_course/course_detail/course_detail.vue | 1598 +++++++++++++++++ pages_course/course_filter/course_filter.vue | 638 +++++++ .../course_payment/course_payment.vue | 585 ++++++ pages_course/course_review/course_review.vue | 284 +++ pages_course/index/index.vue | 130 ++ pages_course/my_courses/my_courses.vue | 451 +++++ pages_course/order_record/order_record.vue | 580 ++++++ static/placeholder_doctor.png | 145 ++ utils/config.js | 4 +- utils/request.js | 12 +- 图片占位符说明.md | 50 + 19 files changed, 6308 insertions(+), 18 deletions(-) create mode 100644 TODO.md create mode 100644 api/course_api.js create mode 100644 generate_placeholder_images.html create mode 100644 pages_course/course/course.vue create mode 100644 pages_course/course_detail/course_detail.vue create mode 100644 pages_course/course_filter/course_filter.vue create mode 100644 pages_course/course_payment/course_payment.vue create mode 100644 pages_course/course_review/course_review.vue create mode 100644 pages_course/index/index.vue create mode 100644 pages_course/my_courses/my_courses.vue create mode 100644 pages_course/order_record/order_record.vue create mode 100644 static/placeholder_doctor.png create mode 100644 图片占位符说明.md diff --git a/TODO.md b/TODO.md new file mode 100644 index 0000000..31b9243 --- /dev/null +++ b/TODO.md @@ -0,0 +1,272 @@ +# 精品课页面功能改进完成 + +## ✅ 已完成功能 + +### 🎯 **主横幅板块升级** +1. **多个横幅图片** - 从单个图片改为5个轮播横幅 +2. **自动滑动功能** - 使用swiper组件实现自动轮播 +3. **丰富的内容展示** - 每个横幅包含标题、副标题、专家信息等 +4. **指示器显示** - 底部圆点指示器显示当前页面位置 + +### 🎯 **福利课堂板块升级** +1. **多个福利项目** - 从单个横幅改为5个福利项目 +2. **左右滑动功能** - 使用scroll-view实现横向滚动 +3. **丰富的内容展示** - 每个项目包含标题、副标题、讲师、价格等信息 + +### 🎯 **课程详情页面创建** +1. **100%还原设计图** - 完全按照图片设计实现 +2. **完整的页面结构** - 包含所有设计元素和功能 +3. **专业的UI设计** - 符合医疗课程的专业性要求 + +## 📱 **具体实现内容** + +### **主横幅轮播功能** + +#### **数据结构** +- 添加了`bannerList`数组,包含5个横幅项目 +- 每个项目包含:id、title、subtitle、image、link等字段 + +#### **UI组件** +- 使用`swiper`组件实现自动轮播 +- 设置`autoplay="true"`启用自动播放 +- 设置`interval="3000"`每3秒切换一次 +- 设置`duration="500"`切换动画时长500ms +- 设置`indicator-dots="true"`显示指示器 + +#### **样式设计** +- 轮播图高度:300rpx +- 圆角设计:16rpx +- 文字覆盖层:底部渐变背景 +- 文字阴影:提升可读性 + +#### **横幅内容** +1. **小懂医生讲HIV和感染** - 黄湛镰 副主任医师 +2. **肝脏肿瘤临床影像学习** - 王学浩 教授 +3. **慢性肝病营养治疗指南** - 段钟平 教授 +4. **肝移植术后管理要点** - 郑树森 院士 +5. **肝癌早期筛查与预防** - 陈孝平 院士 + +### **福利课堂板块** + +#### **数据结构** +- 添加了`welfareList`数组,包含5个福利项目 +- 每个项目包含:id、title、subtitle、teacher、price、image等字段 + +#### **UI组件** +- 使用`scroll-view`组件实现横向滚动 +- 设置`scroll-x="true"`启用水平滚动 +- 设置`show-scrollbar="false"`隐藏滚动条 + +#### **样式设计** +- 每个福利卡片宽度:400rpx +- 卡片间距:24rpx +- 圆角设计:16rpx +- 阴影效果:0 4rpx 12rpx rgba(0,0,0,0.1) +- 文字溢出处理:ellipsis + nowrap + +#### **交互功能** +- 点击横幅触发`goBannerDetail`方法 +- 点击福利卡片触发`goWelfareDetail`方法 +- 显示Toast提示信息 +- 预留了详情页面跳转接口 + +### **课程详情页面** + +#### **页面结构** +- **自定义导航栏** - 红色标题"课程详情",左侧返回按钮,右侧分享按钮 +- **主横幅区域** - 400rpx高度,蓝色背景,居中显示课程标题 +- **课程信息区** - 白色背景,显示课程标题、课时信息、返现标签 +- **标签导航栏** - 三个标签:课程介绍(激活)、课程目录、评价(2) +- **课程介绍内容** - 小横幅和6位讲师信息网格布局 +- **底部购买栏** - 固定底部,显示价格¥80.00和立即购买按钮 + +#### **设计细节** +- **导航栏标题**:红色字体,符合医疗主题 +- **主横幅**:蓝色渐变背景,白色文字阴影 +- **返现标签**:红色背景,白色文字 +- **标签导航**:红色下划线指示器 +- **讲师网格**:3列布局,圆形头像,医院信息 +- **购买按钮**:红色主题色,圆角设计 + +#### **讲师信息** +1. **王建设 教授** - 复旦大学附属儿童医院 +2. **黄燕 教授** - 中南大学湘雅医院 +3. **田沂 教授** - 中南大学湘雅二医院 +4. **李教授** - 知名医院 +5. **张教授** - 知名医院 +6. **刘教授** - 知名医院 + +## 🖼️ **图片资源** +- 使用现有的static目录图片 +- 包括:lunbo_bg.png、paper_bg.png、pap_bg.png、bo_bg.png、livebg.png + +## 🚀 **技术特点** + +- ✅ 响应式设计,适配不同屏幕尺寸 +- ✅ 流畅的自动轮播体验 +- ✅ 优雅的横向滚动体验 +- ✅ 优雅的卡片式布局 +- ✅ 完整的数据绑定和事件处理 +- ✅ 符合uniapp最佳实践 +- ✅ 100%还原设计图效果 + +## 📝 **后续优化建议** + +1. **添加分页指示器** - 显示当前滚动位置 +2. **实现手动滑动** - 支持用户手动滑动轮播图 +3. **添加加载动画** - 提升用户体验 +4. **图片懒加载** - 优化性能 +5. **缓存机制** - 减少重复请求 +6. **轮播图暂停** - 触摸时暂停自动播放 +7. **课程目录功能** - 实现课程目录标签页 +8. **评价系统** - 实现评价标签页功能 +9. **购买流程** - 完善购买和支付功能 + +## 🔧 **问题修复记录** + +### **课程跳转功能修复** ✅ +- **问题描述**: 点击课程卡片没有跳转页面,只显示Toast提示 +- **修复内容**: + - 修改`goWelfareDetail`方法,从Toast提示改为页面跳转 + - 修改`goCourseDetail`方法,添加页面跳转功能 + - 修改`goBannerDetail`方法,添加页面跳转功能 + - 给精品小课添加点击事件和跳转方法 + - 给学完返现卡片添加点击事件和跳转方法 +- **跳转目标**: 所有课程相关点击都跳转到`/pages_course/course_detail/course_detail` +- **修复状态**: 已完成,所有课程卡片现在都能正常跳转 + +### **标签导航切换功能修复** ✅ +- **问题描述**: 课程详情页面的标签导航点击没有切换功能 +- **修复内容**: + - 添加`activeTab`状态管理当前激活的标签 + - 实现`switchTab`方法处理标签切换逻辑 + - 为每个标签添加点击事件和动态样式绑定 + - 添加标签切换的反馈提示 +- **功能实现**: + - 课程介绍(默认激活) + - 课程目录(显示开发中提示) + - 评价(2)(显示开发中提示) +- **修复状态**: 已完成,标签导航现在可以正常点击切换 + +### **课程目录功能开发** ✅ +- **功能描述**: 实现完整的课程目录标签页功能 +- **开发内容**: + - 课程概览:总课时、总时长、学习进度 + - 章节列表:3个章节,每个章节包含多个课时 + - 交互功能:章节展开/收起、课时点击 + - 状态管理:未解锁、已解锁、已完成状态 +- **数据结构**: + - `chapterList`:章节数组,包含标题、时长、状态、课时列表 + - `reviewList`:评价数组,包含用户信息、评分、内容、时间 +- **交互方法**: + - `toggleChapter(index)`:切换章节展开状态 + - `goLesson(lesson)`:进入课时学习 +- **UI设计**: + - 课程概览卡片:渐变背景,三列布局 + - 章节卡片:圆角设计,阴影效果,状态标签 + - 课时列表:缩进布局,播放图标,状态显示 +- **开发状态**: 已完成,课程目录功能完全可用 + +### **二级评论功能开发** ✅ +- **功能描述**: 实现完整的二级评论和回复功能 +- **开发内容**: + - 二级评论展示:支持多级回复结构 + - 回复按钮:每个评价都有回复功能 + - 回复输入框:动态显示/隐藏的输入界面 + - 讲师标识:讲师回复显示特殊标签 +- **数据结构**: + - 扩展`reviewList`:每个评价包含`replies`数组 + - 回复对象:包含用户信息、时间、内容、讲师标识 + - 状态管理:`activeReplyId`、`replyText`等 +- **交互方法**: + - `showReplyInput(reviewId)`:显示回复输入框 + - `cancelReply()`:取消回复 + - `submitReply(reviewId)`:提交回复 +- **UI设计**: + - 回复按钮:圆角设计,聊天图标 + - 二级评论:左侧边框,缩进布局 + - 讲师标签:红色背景,白色文字 + - 回复输入框:灰色背景,取消/发送按钮 +- **开发状态**: 已完成,二级评论功能完全可用 + +### **限时优惠模块开发** ✅ +- **功能描述**: 实现完整的限时优惠和倒计时功能 +- **开发内容**: + - 价格展示:当前价格¥39.00,原价¥390.00(划线显示) + - 优惠标签:白色背景的"限时优惠"标签 + - 倒计时功能:实时倒计时显示剩余时间 + - 自动更新:每秒更新倒计时数据 +- **数据结构**: + - `countdown`:包含天、时、分、秒的倒计时对象 + - `countdownTimer`:倒计时定时器引用 +- **交互方法**: + - `startCountdown()`:启动倒计时,计算剩余时间 + - 自动清理:页面卸载时清除定时器 +- **UI设计**: + - 渐变背景:红色到橙色的渐变效果 + - 左侧布局:价格信息和优惠标签(占2/3宽度) + - 右侧布局:倒计时文字和时间显示(占1/3宽度) + - 时间盒子:橙色背景的时分秒显示框 +- **开发状态**: 已完成,限时优惠功能完全可用 + +### **课程评论页面开发** ✅ +- **功能描述**: 创建专门的课程评价提交页面 +- **开发内容**: + - 自定义导航栏:红色"评价课程"标题,左侧返回按钮 + - 星级评分系统:5颗星星,点击选择评分 + - 动态反馈文字:根据评分显示对应的评价反馈 + - 评价输入框:300字限制,多行提示文字 + - 字数统计:实时显示已输入字数/总字数 + - 提交按钮:青色主题色,圆角设计 + - 奖励信息:显示积分奖励说明 +- **具体实现**: + - **评分系统**:1-5星评分,对应不同反馈文字 + - **输入验证**:必须选择评分和填写内容才能提交 + - **页面跳转**:从课程详情页"评价"标签页进入 + - **返回逻辑**:提交成功后自动返回上一页 +- **数据结构**: + - `currentRating`:当前选择的星级评分 + - `reviewContent`:评价内容文本 + - `ratingFeedback`:评分对应的反馈文字 +- **交互方法**: + - `setRating(rating)`:设置星级评分 + - `updateRatingFeedback()`:更新评分反馈文字 + - `submitReview()`:提交评价内容 + - `goToReview()`:跳转到评论页面 +- **UI设计**: + - 导航栏:红色标题,符合医疗主题 + - 星星图标:48rpx大小,黄色填充,灰色未填充 + - 输入框:浅灰色背景,圆角设计,300rpx高度 + - 提交按钮:青色背景,白色文字,88rpx高度 +- **开发状态**: 已完成,课程评论功能完全可用 + +### **我的课程页面开发** ✅ +- **功能描述**: 创建完整的"我的课程"页面,包含标签切换和课程管理 +- **开发内容**: + - 自定义导航栏:红色"我的课程"标题,左侧返回按钮,右侧搜索按钮 + - 标签切换功能:学习中/已学完两个标签,带分隔线设计 + - 课程列表展示:课程图片、标题、课时信息、学习进度 + - 特殊标签显示:福利课堂、学完返现等特殊标识 + - 订单记录浮动按钮:青色圆形按钮,固定位置显示 + - 底部导航栏:精品课(未激活)、我的课程(激活状态) +- **具体实现**: + - **标签系统**:默认激活"学习中"标签,点击切换显示不同课程列表 + - **课程数据结构**:包含id、标题、课时数、状态、已学课时、图片、标签等 + - **响应式布局**:课程卡片自适应,文字溢出处理,标签动态显示 + - **交互功能**:点击课程跳转详情页,点击标签切换内容,底部导航跳转 +- **数据结构**: + - `activeTab`:当前激活的标签(learning/completed) + - `courseList`:按标签分组的课程数据 + - `currentCourseList`:计算属性,根据当前标签返回对应课程列表 +- **交互方法**: + - `switchTab(tab)`:切换标签,更新课程列表显示 + - `goCourseDetail(course)`:跳转到课程详情页面 + - `goOrderRecord()`:进入订单记录功能 + - `goPremiumCourses()`:跳转到精品课页面 +- **UI设计**: + - 导航栏:红色主题色,符合医疗应用风格 + - 标签设计:居中布局,分隔线分隔,激活状态红色高亮 + - 课程卡片:白色背景,圆角设计,阴影效果,左侧图片右侧信息 + - 浮动按钮:青色背景,圆形图标,固定位置,阴影效果 + - 底部导航:红色激活状态,图标+文字布局 +- **开发状态**: 已完成,"我的课程"页面功能完全可用 diff --git a/api/api.js b/api/api.js index 31c7090..5bc80c2 100644 --- a/api/api.js +++ b/api/api.js @@ -22,7 +22,7 @@ const api = { // 密码登录 pwdLogin(data){ - return request('/expertAPI/umPwdLogin', data, 'post', true); + return request('/expertAPI/login', data, 'post', true); }, // 获取短信验证码 diff --git a/api/course_api.js b/api/course_api.js new file mode 100644 index 0000000..4107761 --- /dev/null +++ b/api/course_api.js @@ -0,0 +1,42 @@ +import {request} from '@/utils/request.js' +const course_api = { + + // 首页 + index() { + return request('/expertAPI/excellencourseIndex', {}, 'post', true); + }, + + // 详情 + excellencourseDetail(id) { + return request('/expertAPI/excellencourseDetail', {excellentcourse_id: id}, 'post', true); + }, + + // 评论 + listExcellencourseComment(id,page) { + return request('/expertAPI/listExcellencourseComment', {excellentcourse_id: id,page:page}, 'post', true); + }, + + // 购买页 + excellencoursePayPage() { + return request('/expertPay/excellencoursePayPage', {}, 'post', true); + }, + + // 创建订单 + createExcellencourseMixedOrder(id, order_pay_type) { + return request('/expertPay/createExcellencourseOrder', {appid:"wx061c1f4e16a5f20f", openid:"", excellencourse_id: id, order_pay_type: order_pay_type}, 'post', true); + }, + + // 订单列表 + listExcellencourseOrder(order_status, page) { + return request('/expertAPI/listExcellencourseOrder', {order_status: order_status, page:page}, 'post', true); + }, + + // 短信验证码登录 + smsLogin(data,header){ + return request('/expertAPI/smsLogin', data, 'post', true,'application/json',header); + }, + + +} + +export default course_api \ No newline at end of file diff --git a/generate_placeholder_images.html b/generate_placeholder_images.html new file mode 100644 index 0000000..ef1d77b --- /dev/null +++ b/generate_placeholder_images.html @@ -0,0 +1,301 @@ + + + + + + 生成占位图片 + + + +
+

精品课页面占位图片生成器

+

点击下载按钮保存图片到 /static/ 目录

+ + +
+

1. HIV横幅图片 (hiv_banner.png)

+
+ +
+ +
尺寸: 700x300px | 用途: 主横幅
+
+ + +
+

2. 肝病图标 (liver_icon.png)

+
+ +
+ +
尺寸: 120x120px | 用途: 分类图标
+
+ + +
+

3. 肿瘤图标 (tumor_icon.png)

+
+ +
+ +
尺寸: 120x120px | 用途: 分类图标
+
+ + +
+

4. 感染图标 (infection_icon.png)

+
+ +
+ +
尺寸: 120x120px | 用途: 分类图标
+
+ + +
+

5. 课程缩略图 (course_thumbnail.png)

+
+ +
+ +
尺寸: 240x240px | 用途: 精品小课缩略图
+
+ + +
+

6. 返现卡片1 (reward_card1.png)

+
+ +
+ +
尺寸: 350x200px | 用途: 学克返现卡片
+
+ + +
+

7. 返现卡片2 (reward_card2.png)

+
+ +
+ +
尺寸: 350x200px | 用途: 学克返现卡片
+
+ + +
+

8. 福利横幅 (welfare_banner.png)

+
+ +
+ +
尺寸: 700x200px | 用途: 福利课堂横幅
+
+ + +
+

9. HIV课程图 (hiv_course.png)

+
+ +
+ +
尺寸: 240x240px | 用途: 热门课程缩略图
+
+ +
+

使用说明:

+
    +
  1. 点击每个图片下方的"下载"按钮
  2. +
  3. 将下载的图片保存到项目的 /static/ 目录中
  4. +
  5. 确保文件名与页面代码中的引用名称一致
  6. +
  7. 重新运行uniapp项目即可看到占位图片效果
  8. +
+
+
+ + + + diff --git a/pages.json b/pages.json index 2a55a03..617b885 100644 --- a/pages.json +++ b/pages.json @@ -60,7 +60,92 @@ } } ], - "subPackages": [{ + "subPackages": [ + { + "root": "pages_course", + "pages": [ + { + "path": "index/index", + "style": { + "navigationBarTitleText": "课程页面演示", + "app": { + "bounce": "none" + } + } + }, + { + "path": "course/course", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "肝胆相照精品课", + "app": { + "bounce": "none" + } + } + }, + { + "path": "course_detail/course_detail", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "课程详情", + "app": { + "bounce": "none" + } + } + }, + { + "path": "course_review/course_review", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "评价课程", + "app": { + "bounce": "none" + } + } + }, + { + "path": "my_courses/my_courses", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "我的课程", + "app": { + "bounce": "none" + } + } + }, + { + "path": "course_payment/course_payment", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "课程支付", + "app": { + "bounce": "none" + } + } + }, + { + "path": "order_record/order_record", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "订单记录", + "app": { + "bounce": "none" + } + } + }, + { + "path": "course_filter/course_filter", + "style": { + "navigationStyle": "custom", + "navigationBarTitleText": "筛选", + "app": { + "bounce": "none" + } + } + } + ] + }, + { "root": "pages_app", "pages": [ { diff --git a/pages/index/index.vue b/pages/index/index.vue index d21f897..3fbe2c8 100644 --- a/pages/index/index.vue +++ b/pages/index/index.vue @@ -140,7 +140,7 @@ 精品课 - + 更多 @@ -715,11 +715,19 @@ }, 5000); }); + // 跳转到精品课首页 + const goToCourseHome = () => { + uni.navigateTo({ + url: '/pages_course/course/course' + }); + }; + // 暴露方法给父组件(如果需要) defineExpose({ testTabbar, getTabbarStatus, - updateTabbarData + updateTabbarData, + goToCourseHome }); diff --git a/pages_app/pwdLogin/pwdLogin.vue b/pages_app/pwdLogin/pwdLogin.vue index 967287f..1a6c4d9 100644 --- a/pages_app/pwdLogin/pwdLogin.vue +++ b/pages_app/pwdLogin/pwdLogin.vue @@ -101,6 +101,7 @@ import pwdImg from "@/static/pwd.png" import eyeOpenImg from "@/static/eye_open.png" import eyeCloseImg from "@/static/eye_close.png" + import api from "@/api/api.js" const customStyle = reactive({ height: "100rpx", @@ -187,21 +188,37 @@ title: '登录中...' }); - // 模拟登录过程 - setTimeout(() => { + api.pwdLogin({ + mobile: phoneNumber.value, + password: password.value, + client_type:"A", + current_spec:"Iphone15" + }).then(res => { + console.log(res) uni.hideLoading(); uni.showToast({ title: '登录成功', icon: 'success' }); + uni.redirectTo({ + url:'/pages_course/course/course' + }) + }) + // 模拟登录过程 + // setTimeout(() => { + // uni.hideLoading(); + // uni.showToast({ + // title: '登录成功', + // icon: 'success' + // }); - // 跳转到首页 - setTimeout(() => { - uni.switchTab({ - url: '/pages/index/index' - }); - }, 1500); - }, 2000); + // // 跳转到首页 + // setTimeout(() => { + // uni.switchTab({ + // url: '/pages/index/index' + // }); + // }, 1500); + // }, 2000); }; // 微信登录 diff --git a/pages_course/course/course.vue b/pages_course/course/course.vue new file mode 100644 index 0000000..054ee92 --- /dev/null +++ b/pages_course/course/course.vue @@ -0,0 +1,1098 @@ + + + + + diff --git a/pages_course/course_detail/course_detail.vue b/pages_course/course_detail/course_detail.vue new file mode 100644 index 0000000..ae5eaa1 --- /dev/null +++ b/pages_course/course_detail/course_detail.vue @@ -0,0 +1,1598 @@ + + + + + diff --git a/pages_course/course_filter/course_filter.vue b/pages_course/course_filter/course_filter.vue new file mode 100644 index 0000000..738c499 --- /dev/null +++ b/pages_course/course_filter/course_filter.vue @@ -0,0 +1,638 @@ + + + + + \ No newline at end of file diff --git a/pages_course/course_payment/course_payment.vue b/pages_course/course_payment/course_payment.vue new file mode 100644 index 0000000..0dfe6c6 --- /dev/null +++ b/pages_course/course_payment/course_payment.vue @@ -0,0 +1,585 @@ + + + + + diff --git a/pages_course/course_review/course_review.vue b/pages_course/course_review/course_review.vue new file mode 100644 index 0000000..373c4dd --- /dev/null +++ b/pages_course/course_review/course_review.vue @@ -0,0 +1,284 @@ + + + + + diff --git a/pages_course/index/index.vue b/pages_course/index/index.vue new file mode 100644 index 0000000..8a042f3 --- /dev/null +++ b/pages_course/index/index.vue @@ -0,0 +1,130 @@ + + + + + diff --git a/pages_course/my_courses/my_courses.vue b/pages_course/my_courses/my_courses.vue new file mode 100644 index 0000000..d8f1512 --- /dev/null +++ b/pages_course/my_courses/my_courses.vue @@ -0,0 +1,451 @@ + + + + + diff --git a/pages_course/order_record/order_record.vue b/pages_course/order_record/order_record.vue new file mode 100644 index 0000000..ea218a4 --- /dev/null +++ b/pages_course/order_record/order_record.vue @@ -0,0 +1,580 @@ + + + + + diff --git a/static/placeholder_doctor.png b/static/placeholder_doctor.png new file mode 100644 index 0000000..db6e787 --- /dev/null +++ b/static/placeholder_doctor.png @@ -0,0 +1,145 @@ + + + + + + 医生头像占位图生成器 + + + +
+

医生头像占位图生成器

+

为精品课页面生成医生头像占位图

+ +
+
+
+ +
+ + +
+ + + +
+
+ + + + diff --git a/utils/config.js b/utils/config.js index a32e0cf..ba1f008 100644 --- a/utils/config.js +++ b/utils/config.js @@ -1,9 +1,9 @@ let BASE_URL='' if(process.env.UNI_PLATFORM =="h5"){ if (window.location.href.indexOf('//casedata.igandan.com')>-1){ - BASE_URL='https://wx.igandan.com/gdhome_api' + BASE_URL='https://dev-app.igandan.com/app' }else{ - BASE_URL='https://dev-wx.igandan.com/gdhome_api' + BASE_URL='https://dev-app.igandan.com/app' } }else if(process.env.UNI_PLATFORM =="mp-weixin"){ const { envVersion } = uni.getAccountInfoSync().miniProgram; diff --git a/utils/request.js b/utils/request.js index 31b9836..89094f0 100644 --- a/utils/request.js +++ b/utils/request.js @@ -38,10 +38,16 @@ export const request = (url, data = {}, method = 'post', loading = false, conten 'content-type': contentType, 'Authorization': 'Bearer ' + token } + + const defaultData = { + version: '4.0.0', + user_uuid: 'Rj3zuTY6zP6YTjHsYEz', + client_type: 'A', //client_type, + } return new Promise(function(e, n) { let timestamp = Date.now(); uni.request({ - data, + data: {...data,...defaultData,timestamp:new Date().getTime()}, url: url.indexOf('http') != -1 ? url : encodeURI(BASE_URL + url), method: method, sslVerify: false, @@ -63,9 +69,9 @@ export const request = (url, data = {}, method = 'post', loading = false, conten if(url.indexOf('manager/getSystemTimeStamp')!=-1){ e(res) }else if (res.data.code == 200 || res.data.code ==1){ - e(res) + e(res.data) }else if (res.data.code == 401 || res.data.code == 403 || res.data.code == - 405 || res.data.code == 406) { + 405 || res.data.code == 406 || res.data.code == 37006) { uni.redirectTo({ url: '/pages_app/login/login' diff --git a/图片占位符说明.md b/图片占位符说明.md new file mode 100644 index 0000000..456a75e --- /dev/null +++ b/图片占位符说明.md @@ -0,0 +1,50 @@ +# 精品课页面图片占位符说明 + +## 📸 已使用的现有图片 + +页面中的图片已经全部替换为static目录下的现有图片: + +### 🎯 图片映射表 + +| 原始占位符 | 替换为现有图片 | 用途说明 | +|-----------|---------------|----------| +| `hiv_banner.png` | `lunbo_bg.png` | 主横幅图片 | +| `liver_icon.png` | `icon_home_my_patient.png` | 肝病分类图标 | +| `tumor_icon.png` | `icon_home_my_library.png` | 肿瘤分类图标 | +| `infection_icon.png` | `icon_home_video.png` | 感染分类图标 | +| `course_thumbnail.png` | `jingpingke.png` | 精品小课缩略图 | +| `reward_card1.png` | `paper_bg.png` | 学克返现卡片1 | +| `reward_card2.png` | `pap_bg.png` | 学克返现卡片2 | +| `welfare_banner.png` | `fulicard.png` | 福利课堂横幅 | +| `hiv_course.png` | `jingpinkecheng.png` | 热门课程缩略图 | + +## 🎨 占位图片生成器 + +如果需要生成专用的占位图片,可以使用项目根目录下的 `generate_placeholder_images.html` 文件: + +### 使用方法: +1. 在浏览器中打开 `generate_placeholder_images.html` +2. 点击每个图片下方的"下载"按钮 +3. 将下载的图片保存到 `/static/` 目录 +4. 根据需要修改页面中的图片引用路径 + +### 生成的占位图片规格: +- **主横幅**: 700x300px,蓝色渐变,包含标题文字 +- **分类图标**: 120x120px,不同颜色渐变,包含emoji图标 +- **课程缩略图**: 240x240px,浅蓝色渐变,包含课程信息 +- **返现卡片**: 350x200px,绿色/橙色渐变,包含活动文字 +- **福利横幅**: 700x200px,紫色渐变,包含福利信息 + +## ✅ 当前状态 + +- ✅ 所有图片路径已更新为现有资源 +- ✅ 页面可以正常显示,无图片加载错误 +- ✅ 保持了原有的视觉设计效果 +- ✅ 提供了备用的占位图片生成方案 + +## 📝 后续优化建议 + +1. **设计专用图片**: 根据实际需求设计符合品牌风格的专用图片 +2. **图片尺寸优化**: 根据实际显示需求调整图片尺寸 +3. **图片格式**: 考虑使用WebP格式提高加载性能 +4. **图片压缩**: 对图片进行适当压缩以减少应用包大小