mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-27 01:32:10 +08:00 
			
		
		
		
	[new feature] ImagePreview: add onChange option (#3630)
This commit is contained in:
		
							parent
							
								
									045c75669b
								
							
						
					
					
						commit
						fbd751a641
					
				| @ -228,7 +228,7 @@ export default sfc({ | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     onChange(active) { | ||||
|     onSwipeChange(active) { | ||||
|       this.resetScale(); | ||||
|       this.active = active; | ||||
|       this.$emit('change', active); | ||||
| @ -261,7 +261,7 @@ export default sfc({ | ||||
|         indicatorColor="white" | ||||
|         initialSwipe={this.startPosition} | ||||
|         showIndicators={this.showIndicators} | ||||
|         onChange={this.onChange} | ||||
|         onChange={this.onSwipeChange} | ||||
|       > | ||||
|         {images.map((image, index) => { | ||||
|           const props = { | ||||
|  | ||||
| @ -94,7 +94,8 @@ export default { | ||||
| | showIndex | Whether to show index | `Boolean` | `true` | | ||||
| | showIndicators | Whether to show indicators | `Boolean` | `false` | | ||||
| | loop | Whether to enable loop | `Boolean` | `true` | | ||||
| | onClose | Close callback | `Function` | - | | ||||
| | onClose | Triggered when close | `Function` | - | | ||||
| | onChange | Triggered when current image change | `Function` | - | | ||||
| | closeOnPopstate | Whether to close when popstate | `Boolean` | `false` | | ||||
| | asyncClose | Whether to enable async close | `Boolean` | `false` | | ||||
| | className | Custom className | `String | Array | Object` | - | | ||||
|  | ||||
| @ -24,6 +24,12 @@ const initInstance = () => { | ||||
|     el: document.createElement('div') | ||||
|   }); | ||||
|   document.body.appendChild(instance.$el); | ||||
| 
 | ||||
|   instance.$on('change', index => { | ||||
|     if (instance.onChange) { | ||||
|       instance.onChange(index); | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| const ImagePreview = (images, startPosition = 0) => { | ||||
|  | ||||
| @ -9,6 +9,19 @@ exports[`index slot 1`] = ` | ||||
| </div> | ||||
| `; | ||||
| 
 | ||||
| exports[`lazy-load prop 1`] = ` | ||||
| <div class="van-image-preview" name="van-fade"> | ||||
|   <div class="van-image-preview__index">1/3</div> | ||||
|   <div class="van-swipe"> | ||||
|     <div class="van-swipe__track" style="width: 0px; transition-duration: 0ms; transform: translateX(0px);"> | ||||
|       <div class="van-swipe-item" style="width: 0px; height: 100%; transform: translateX(0px);"><img class="van-image-preview__image" style="transition: .3s all;"></div> | ||||
|       <div class="van-swipe-item" style="width: 0px; height: 100%; transform: translateX(0px);"><img class="van-image-preview__image"></div> | ||||
|       <div class="van-swipe-item" style="width: 0px; height: 100%; transform: translateX(0px);"><img class="van-image-preview__image"></div> | ||||
|     </div> | ||||
|   </div> | ||||
| </div> | ||||
| `; | ||||
| 
 | ||||
| exports[`render image 1`] = ` | ||||
| <div class="van-image-preview" name="van-fade"> | ||||
|   <div class="van-image-preview__index">1/3</div> | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| import Vue from 'vue'; | ||||
| import ImagePreview from '..'; | ||||
| import ImagePreviewVue from '../ImagePreview'; | ||||
| import { mount, trigger, triggerDrag, transitionStub } from '../../../test/utils'; | ||||
| import { mount, trigger, triggerDrag, transitionStub, later } from '../../../test/utils'; | ||||
| 
 | ||||
| transitionStub(); | ||||
| 
 | ||||
| @ -64,7 +64,7 @@ test('function call', done => { | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| test('function call options', done => { | ||||
| test('onClose option', async done => { | ||||
|   const onClose = jest.fn(); | ||||
|   const instance = ImagePreview({ | ||||
|     images, | ||||
| @ -75,7 +75,8 @@ test('function call options', done => { | ||||
|   instance.$emit('input', true); | ||||
|   expect(onClose).toHaveBeenCalledTimes(0); | ||||
| 
 | ||||
|   Vue.nextTick(() => { | ||||
|   await later(); | ||||
| 
 | ||||
|   const wrapper = document.querySelector('.van-image-preview'); | ||||
|   const swipe = wrapper.querySelector('.van-swipe__track'); | ||||
|   triggerDrag(swipe, 0, 0); | ||||
| @ -83,6 +84,19 @@ test('function call options', done => { | ||||
|   expect(onClose).toHaveBeenCalledWith({ index: 0, url: 'https://img.yzcdn.cn/1.png' }); | ||||
|   done(); | ||||
| }); | ||||
| 
 | ||||
| test('onChange option', async done => { | ||||
|   const instance = ImagePreview({ | ||||
|     images, | ||||
|     startPostion: 0, | ||||
|     onChange(index) { | ||||
|       expect(index).toEqual(2); | ||||
|       done(); | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   const swipe = instance.$el.querySelector('.van-swipe__track'); | ||||
|   triggerDrag(swipe, 1000, 0); | ||||
| }); | ||||
| 
 | ||||
| test('register component', () => { | ||||
| @ -137,3 +151,18 @@ test('closeOnPopstate', () => { | ||||
|   trigger(window, 'popstate'); | ||||
|   expect(wrapper.emitted('input')[1]).toBeFalsy(); | ||||
| }); | ||||
| 
 | ||||
| test('lazy-load prop', () => { | ||||
|   const wrapper = mount(ImagePreviewVue, { | ||||
|     propsData: { | ||||
|       images, | ||||
|       lazyLoad: true | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   wrapper.setProps({ | ||||
|     value: true | ||||
|   }); | ||||
| 
 | ||||
|   expect(wrapper).toMatchSnapshot(); | ||||
| }); | ||||
|  | ||||
| @ -107,6 +107,7 @@ export default { | ||||
| | showIndicators | 是否显示轮播指示器 | `Boolean` | `false` | 1.3.10 | | ||||
| | loop | 是否开启循环播放 | `Boolean` | `true` | 1.4.4 | | ||||
| | onClose | 关闭时的回调函数 | `Function` | - | 1.1.16 | | ||||
| | onChange | 切换图片时的回调函数,回调参数为当前索引 | `Function` | - | 2.0.3 | | ||||
| | asyncClose | 是否开启异步关闭 | `Boolean` | `false` | 1.4.8 | | ||||
| | closeOnPopstate | 是否在页面回退时自动关闭 | `Boolean` | `false` | 2.0.0 | | ||||
| | className | 自定义类名 | `String | Array | Object` | - | 1.5.2 | | ||||
|  | ||||
							
								
								
									
										3
									
								
								types/image-preview.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								types/image-preview.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -12,7 +12,8 @@ export type ImagePreviewOptions = string[] | { | ||||
|   asyncClose?: boolean; | ||||
|   showIndicators?: boolean; | ||||
|   closeOnPopstate?: boolean; | ||||
|   onClose?: () => any; | ||||
|   onClose?: () => void; | ||||
|   onChange?: (index: number) => void; | ||||
| }; | ||||
| 
 | ||||
| export class VanImagePreview extends VanPopupMixin { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user