108 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
| 	<!-- #ifdef APP-NVUE -->
 | |
| 	<cell>
 | |
| 		<!-- #endif -->
 | |
| 		<view class="uni-list-ad">
 | |
| 			<view v-if="borderShow" :class="{'uni-list--border':border,'uni-list-item--first':isFirstChild}"></view>
 | |
| 			<ad style="width: 200px;height: 300px;border-width: 1px;border-color: red;border-style: solid;" adpid="1111111111"
 | |
| 			 unit-id="" appid="" apid="" type="feed" @error="aderror" @close="closeAd"></ad>
 | |
| 		</view>
 | |
| 		<!-- #ifdef APP-NVUE -->
 | |
| 	</cell>
 | |
| 	<!-- #endif -->
 | |
| 
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| 	// #ifdef APP-NVUE
 | |
| 	const dom = uni.requireNativePlugin('dom');
 | |
| 	// #endif
 | |
| 	export default {
 | |
| 		name: 'UniListAd',
 | |
| 		props: {
 | |
| 			title: {
 | |
| 				type: String,
 | |
| 				default: '',
 | |
| 
 | |
| 			}
 | |
| 		},
 | |
| 		// inject: ['list'],
 | |
| 		data() {
 | |
| 			return {
 | |
| 				isFirstChild: false,
 | |
| 				border: false,
 | |
| 				borderShow: true,
 | |
| 			}
 | |
| 		},
 | |
| 
 | |
| 		mounted() {
 | |
| 			this.list = this.getForm()
 | |
| 			if (this.list) {
 | |
| 				if (!this.list.firstChildAppend) {
 | |
| 					this.list.firstChildAppend = true
 | |
| 					this.isFirstChild = true
 | |
| 				}
 | |
| 				this.border = this.list.border
 | |
| 			}
 | |
| 		},
 | |
| 		methods: {
 | |
| 			/**
 | |
| 			 * 获取父元素实例
 | |
| 			 */
 | |
| 			getForm(name = 'uniList') {
 | |
| 				let parent = this.$parent;
 | |
| 				let parentName = parent.$options.name;
 | |
| 				while (parentName !== name) {
 | |
| 					parent = parent.$parent;
 | |
| 					if (!parent) return false
 | |
| 					parentName = parent.$options.name;
 | |
| 				}
 | |
| 				return parent;
 | |
| 			},
 | |
| 			aderror(e) {
 | |
| 				console.log("aderror: " + JSON.stringify(e.detail));
 | |
| 			},
 | |
| 			closeAd(e) {
 | |
| 				this.borderShow = false
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" >
 | |
| 	.uni-list-ad {
 | |
| 		position: relative;
 | |
| 		border: 1px red solid;
 | |
| 	}
 | |
| 
 | |
| 	.uni-list--border {
 | |
| 		position: relative;
 | |
| 		padding-bottom: 1px;
 | |
| 		/* #ifdef APP-PLUS */
 | |
| 		border-top-color: $uni-border-color;
 | |
| 		border-top-style: solid;
 | |
| 		border-top-width: 0.5px;
 | |
| 		/* #endif */
 | |
| 		margin-left: $uni-spacing-row-lg;
 | |
| 	}
 | |
| 
 | |
| 	/* #ifndef APP-NVUE */
 | |
| 	.uni-list--border:after {
 | |
| 		position: absolute;
 | |
| 		top: 0;
 | |
| 		right: 0;
 | |
| 		left: 0;
 | |
| 		height: 1px;
 | |
| 		content: '';
 | |
| 		-webkit-transform: scaleY(.5);
 | |
| 		transform: scaleY(.5);
 | |
| 		background-color: $uni-border-color;
 | |
| 	}
 | |
| 
 | |
| 	.uni-list-item--first:after {
 | |
| 		height: 0px;
 | |
| 	}
 | |
| 
 | |
| 	/* #endif */
 | |
| </style>
 |