90 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
| <template>
 | |
| 	<view class="u-demo">
 | |
| 		<view class="u-demo-wrap">
 | |
| 			<view class="u-demo-title">演示效果</view>
 | |
| 			<view class="u-demo-area">
 | |
| 				<u-toast ref="uToast"></u-toast>
 | |
| 				<view class="u-no-demo-here">
 | |
| 					请点击弹出遮罩查看效果
 | |
| 				</view>
 | |
| 				<u-mask :show="show" @click="show = false" :zoom="zoom" :duration="duration">
 | |
| 					<view class="warp" v-if="content">
 | |
| 						<view class="rect" @tap.stop></view>
 | |
| 					</view>
 | |
| 				</u-mask>
 | |
| 			</view>
 | |
| 		</view>
 | |
| 		<view class="u-config-wrap">
 | |
| 			<view class="u-config-title u-border-bottom">
 | |
| 				参数配置
 | |
| 			</view>
 | |
| 			<view class="u-config-item">
 | |
| 				<view class="u-item-title">状态</view>
 | |
| 				<u-subsection vibrateShort :current="current" :list="['显示', '隐藏']" @change="showChange"></u-subsection>
 | |
| 			</view>
 | |
| 			<view class="u-config-item">
 | |
| 				<view class="u-item-title">缩放效果</view>
 | |
| 				<u-subsection vibrateShort :list="['是', '否']" @change="zoomChange"></u-subsection>
 | |
| 			</view>
 | |
| 			<view class="u-config-item">
 | |
| 				<view class="u-item-title">内容填充</view>
 | |
| 				<u-subsection vibrateShort current="1" :list="['是', '否']" @change="contentChange"></u-subsection>
 | |
| 			</view>
 | |
| 			<view class="u-config-item">
 | |
| 				<view class="u-item-title">动画时长(ms)</view>
 | |
| 				<u-subsection vibrateShort current="1" :list="['100', '300', '800']" @change="durationChange"></u-subsection>
 | |
| 			</view>
 | |
| 		</view>
 | |
| 	</view>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| 	export default {
 | |
| 		data() {
 | |
| 			return {
 | |
| 				show: false,
 | |
| 				zoom: true,
 | |
| 				duration: 300,
 | |
| 				content: false,
 | |
| 			}
 | |
| 		},
 | |
| 		computed: {
 | |
| 			current() {
 | |
| 				return this.show ? 0 : 1;
 | |
| 			}
 | |
| 		},
 | |
| 		methods: {
 | |
| 			showChange(index) {
 | |
| 				this.show = index == 0 ? true : false;
 | |
| 			},
 | |
| 			zoomChange(index) {
 | |
| 				this.zoom = index == 0 ? true : false;
 | |
| 				this.show = true;
 | |
| 			},
 | |
| 			durationChange(index) {
 | |
| 				this.duration = index == 0 ? 100 : index == 1 ? 300 : 800;
 | |
| 				this.show = true;
 | |
| 			},
 | |
| 			contentChange(index) {
 | |
| 				this.content = index == 0 ? true : false;
 | |
| 				this.show = true;
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| </script>
 | |
| 
 | |
| <style scoped lang="scss">
 | |
| 	.warp {
 | |
| 		display: flex;
 | |
| 		align-items: center;
 | |
| 		justify-content: center;
 | |
| 		height: 100%;
 | |
| 	}
 | |
| 
 | |
| 	.rect {
 | |
| 		width: 120px;
 | |
| 		height: 120px;
 | |
| 		background-color: #fff;
 | |
| 	}
 | |
| </style>
 |