feat: add iframe comp
							parent
							
								
									88c8447840
								
							
						
					
					
						commit
						db864a53e2
					
				|  | @ -0,0 +1,38 @@ | ||||||
|  | <script setup lang="ts"> | ||||||
|  | import { onMounted, ref } from 'vue'; | ||||||
|  | 
 | ||||||
|  | interface IFrameProps { | ||||||
|  |   /** iframe 的源地址 */ | ||||||
|  |   src: string; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const props = defineProps<IFrameProps>(); | ||||||
|  | 
 | ||||||
|  | const loading = ref(true); | ||||||
|  | const height = ref(''); | ||||||
|  | const frameRef = ref<HTMLElement | null>(null); | ||||||
|  | 
 | ||||||
|  | function init() { | ||||||
|  |   height.value = `${document.documentElement.clientHeight - 94.5}px`; | ||||||
|  |   loading.value = false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | onMounted(() => { | ||||||
|  |   setTimeout(() => { | ||||||
|  |     init(); | ||||||
|  |   }, 300); | ||||||
|  | }); | ||||||
|  | // TODO @芋艿:优化:未来使用 vben 自带的内链实现 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div v-loading="loading" :style="`height:${height}`"> | ||||||
|  |     <iframe | ||||||
|  |       ref="frameRef" | ||||||
|  |       :src="props.src" | ||||||
|  |       style="width: 100%; height: 100%" | ||||||
|  |       frameborder="no" | ||||||
|  |       scrolling="auto" | ||||||
|  |     ></iframe> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | export { default as IFrame } from './iframe.vue'; | ||||||
		Loading…
	
		Reference in New Issue
	
	 xingyu4j
						xingyu4j