You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					85 lines
				
				2.2 KiB
			
		
		
			
		
	
	
					85 lines
				
				2.2 KiB
			| 
											3 months ago
										 | <template> | ||
|  |     <view> | ||
|  |         <swiper class="swiper" :current="currentIndex" :vertical="true" @change="handleSwiperChange"> | ||
|  |             <!-- 动态渲染 swiper-item --> | ||
|  |             <swiper-item v-for="(image, imageIndex) in allImages" :key="imageIndex"> | ||
|  |                 <view class="swiper-item" :style="{ backgroundImage: `url(${getImageUrl(image)})`}" | ||
|  | 				@click="image.onClick ? gotoPath('/bmzm/chapter3/index') : null"> | ||
|  |                 </view> | ||
|  |             </swiper-item> | ||
|  |         </swiper> | ||
|  | 		<MusicControl /> | ||
|  |     </view> | ||
|  | </template> | ||
|  | 
 | ||
|  | <script> | ||
|  | import MusicControl from '@/components/MusicControl.vue'; | ||
|  | export default { | ||
|  | 	components: { | ||
|  | 	    MusicControl | ||
|  | 	}, | ||
|  |     data() { | ||
|  |         return { | ||
|  |             currentIndex: 0, | ||
|  |             initialIndex: 1, | ||
|  |             popupIndex: 1, | ||
|  |             // 图片数据结构
 | ||
|  |             chapters: [ | ||
|  |                 { | ||
|  |                     name: 'chapter1', | ||
|  |                     images: [ | ||
|  |                         { url: `chapter1/img11.png` } | ||
|  |                     ] | ||
|  |                 }, | ||
|  |                 { | ||
|  |                     name: 'chapter2', | ||
|  |                     images: [ | ||
|  |                         { url: 'chapter2/img1.png', onClick: true }, | ||
|  |                     ] | ||
|  |                 } | ||
|  |             ] | ||
|  |         }; | ||
|  |     }, | ||
|  |     computed: { | ||
|  |         allImages() { | ||
|  |             return this.chapters.reduce((acc, chapter) => { | ||
|  |                 return acc.concat(chapter.images); | ||
|  |             }, []); | ||
|  |         } | ||
|  |     }, | ||
|  |     onLoad(option) { | ||
|  |         this.initialIndex = option.index; | ||
|  |         // 更新第一章图片路径
 | ||
|  |         this.chapters[0].images[0].url = `chapter1/img${this.initialIndex}.png`; | ||
|  |     }, | ||
|  |     methods: { | ||
|  |         // 处理 swiper 滑动事件
 | ||
|  |         handleSwiperChange(e) { | ||
|  |             this.currentIndex = e.detail.current; | ||
|  |         }, | ||
|  |         // 生成图片完整 URL
 | ||
|  |         getImageUrl(path) { | ||
|  |             if (typeof path === 'object') { | ||
|  |                 path = path.url; | ||
|  |             } | ||
|  |             return `https://static.ticket.sz-trip.com/epicSoul/bmzm/${path}`; | ||
|  |         } | ||
|  |     } | ||
|  | }; | ||
|  | </script> | ||
|  | 
 | ||
|  | <style lang="scss" scoped> | ||
|  | .swiper { | ||
|  |     width: 100vw; | ||
|  |     height: 100vh; | ||
|  | } | ||
|  | 
 | ||
|  | .swiper-item { | ||
|  |     width: 100vw; | ||
|  |     height: 100vh; | ||
|  |     background-size: 100% 100%; | ||
|  | } | ||
|  | .image-popup { | ||
|  |     width: 700rpx; | ||
|  | } | ||
|  | </style> |