179 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
		
		
			
		
	
	
			179 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
|  | # 分享组件说明
 | |||
|  | 
 | |||
|  | ## SpecialSharePage 组件
 | |||
|  | 
 | |||
|  | 特殊场景分享页面组件,通过接口获取base64格式的背景图片。 | |||
|  | 
 | |||
|  | ### 主要特性
 | |||
|  | 
 | |||
|  | - 📱 **响应式**:适配各种屏幕尺寸 | |||
|  | - 🎨 **可定制**:支持样式自定义 | |||
|  | - 🔄 **重试机制**:支持接口调用失败时的重试 | |||
|  | - 🌐 **接口获取**:自动通过接口获取背景图片 | |||
|  | - 🖼️ **Base64支持**:接口返回base64格式的背景图片 | |||
|  | 
 | |||
|  | ### 使用方法
 | |||
|  | 
 | |||
|  | ```vue | |||
|  | <template> | |||
|  |   <SpecialSharePage | |||
|  |     :qrCodeImage="base64QrCodeImage" | |||
|  |     :userInfo="userInfo" | |||
|  |     :isLoaded="true" | |||
|  |     @share-generated="handleShareGenerated" | |||
|  |     @background-image-error="handleError" | |||
|  |     @background-image-retry="handleRetry" | |||
|  |   /> | |||
|  | </template> | |||
|  | 
 | |||
|  | <script> | |||
|  | import SpecialSharePage from '@/components/share/SpecialSharePage.vue' | |||
|  | 
 | |||
|  | export default { | |||
|  |   components: { | |||
|  |     SpecialSharePage, | |||
|  |   }, | |||
|  |   data() { | |||
|  |     return { | |||
|  |       base64QrCodeImage: | |||
|  |         '...', | |||
|  |       userInfo: { | |||
|  |         memberCode: '12345678', | |||
|  |       }, | |||
|  |     } | |||
|  |   }, | |||
|  |   methods: { | |||
|  |     handleShareGenerated(dataUrl) { | |||
|  |       console.log('生成的分享图片:', dataUrl) | |||
|  |       // 处理生成的图片 | |||
|  |     }, | |||
|  |     handleError(error) { | |||
|  |       console.error('背景图片错误:', error) | |||
|  |     }, | |||
|  |     handleRetry(retryCount) { | |||
|  |       console.log('背景图片重试:', retryCount) | |||
|  |     }, | |||
|  |   }, | |||
|  | } | |||
|  | </script> | |||
|  | ``` | |||
|  | 
 | |||
|  | ### Props
 | |||
|  | 
 | |||
|  | | 参数                    | 类型    | 默认值 | 说明                     | | |||
|  | | ----------------------- | ------- | ------ | ------------------------ | | |||
|  | | `qrCodeImage`           | String  | ''     | 二维码图片(base64格式) | | |||
|  | | `userInfo`              | Object  | {}     | 用户信息对象             | | |||
|  | | `isWechat`              | Boolean | false  | 是否为微信环境           | | |||
|  | | `isLoaded`              | Boolean | false  | 是否加载完成             | | |||
|  | | `skipImageVerification` | Boolean | false  | 跳过图片验证(调试用)   | | |||
|  | 
 | |||
|  | ### Events
 | |||
|  | 
 | |||
|  | | 事件名                   | 参数       | 说明             | | |||
|  | | ------------------------ | ---------- | ---------------- | | |||
|  | | `share-generated`        | dataUrl    | 分享图片生成成功 | | |||
|  | | `background-image-error` | error      | 背景图片加载错误 | | |||
|  | | `background-image-retry` | retryCount | 背景图片重试     | | |||
|  | 
 | |||
|  | ### 方法
 | |||
|  | 
 | |||
|  | | 方法名                          | 说明                                 | | |||
|  | | ------------------------------- | ------------------------------------ | | |||
|  | | `generateShareImage()`          | 生成分享图片                         | | |||
|  | | `retryGetBackgroundImage()`     | 手动重试获取背景图                   | | |||
|  | | `getStatusInfo()`               | 获取当前状态信息(调试用)           | | |||
|  | | `handleShareGenerated(dataUrl)` | 处理图片生成成功后的逻辑(内部方法) | | |||
|  | 
 | |||
|  | ### 接口配置
 | |||
|  | 
 | |||
|  | 组件使用 `getSharedImg` 接口获取背景图片: | |||
|  | 
 | |||
|  | ```javascript | |||
|  | // 在 config/login.js 中配置接口 | |||
|  | export const getSharedImg = () => { | |||
|  |   return http.get('/api/share/background') | |||
|  | } | |||
|  | ``` | |||
|  | 
 | |||
|  | 接口应返回以下格式: | |||
|  | 
 | |||
|  | ```javascript | |||
|  | { | |||
|  |   code: 200, | |||
|  |   data: '...', | |||
|  |   message: 'success' | |||
|  | } | |||
|  | ``` | |||
|  | 
 | |||
|  | ### 调试
 | |||
|  | 
 | |||
|  | ```javascript | |||
|  | // 生成分享图片 | |||
|  | this.$refs.specialSharePage.generateShareImage() | |||
|  | 
 | |||
|  | // 手动重试获取背景图 | |||
|  | this.$refs.specialSharePage.retryGetBackgroundImage() | |||
|  | 
 | |||
|  | // 获取当前状态信息 | |||
|  | const status = this.$refs.specialSharePage.getStatusInfo() | |||
|  | console.log('组件状态:', status) | |||
|  | /* | |||
|  | 输出示例: | |||
|  | { | |||
|  |   specialBackgroundImage: '123456 bytes', | |||
|  |   qrCodeImage: '...', | |||
|  |   backgroundImageLoaded: true, | |||
|  |   isLoadingBackground: false, | |||
|  |   imageLoadRetryCount: 0, | |||
|  |   isReady: true | |||
|  | } | |||
|  | */ | |||
|  | ``` | |||
|  | 
 | |||
|  | ### 工作流程
 | |||
|  | 
 | |||
|  | 1. **组件挂载**:自动调用 `getSharedImg` 接口获取背景图 | |||
|  | 2. **显示加载**:显示"正在获取背景图片..."状态 | |||
|  | 3. **接口响应**:处理接口返回的base64背景图数据 | |||
|  | 4. **准备就绪**:背景图和二维码都准备好后可以生成分享图片 | |||
|  | 5. **生成图片**:使用html2canvas截取页面生成分享图片 | |||
|  | 6. **处理结果**: | |||
|  |    - 关闭loading状态 | |||
|  |    - 显示成功提示("图片生成成功,请长按保存") | |||
|  |    - 调用内部 `handleShareGenerated` 方法处理 | |||
|  |    - 通过 `share-generated` 事件通知父组件 | |||
|  | 
 | |||
|  | ### 图片生成流程
 | |||
|  | 
 | |||
|  | ``` | |||
|  | 用户点击生成按钮 | |||
|  |        ↓ | |||
|  | 检查前置条件(二维码、背景图) | |||
|  |        ↓ | |||
|  | 显示 "生成图片中..." loading | |||
|  |        ↓ | |||
|  | 使用 html2canvas 截取页面 | |||
|  |        ↓ | |||
|  | 生成成功 → 关闭loading → 显示成功提示 → 发送事件 | |||
|  |        ↓ | |||
|  | 生成失败 → 关闭loading → 显示错误提示 | |||
|  | ``` | |||
|  | 
 | |||
|  | ### 错误处理
 | |||
|  | 
 | |||
|  | - **接口调用失败**:自动重试最多3次 | |||
|  | - **重试机制**:通过 `background-image-retry` 事件通知重试状态 | |||
|  | - **最终失败**:通过 `background-image-error` 事件通知错误 | |||
|  | 
 | |||
|  | ### 注意事项
 | |||
|  | 
 | |||
|  | 1. 确保 `getSharedImg` 接口返回完整的base64格式图片 | |||
|  | 2. 组件会在mounted生命周期自动调用接口 | |||
|  | 3. 支持手动重试机制,适用于网络不稳定的情况 | |||
|  | 4. 生成的图片为JPEG格式,质量为100% | |||
|  | 5. 组件支持长按保存分享图片 | |||
|  | 6. 接口失败时会显示相应的错误状态 | |||
|  | 7. **图片生成成功后会自动显示提示信息**,无需在父组件中重复处理 | |||
|  | 8. **组件内部和外部都会收到图片生成事件**,可根据需要在父组件中添加额外逻辑 |