iframe添加loading效果

问题:当一个页面嵌入iframe时,iframe加载会有延迟。即在iframe元素展现前,嵌入iframe的父页面会有一段白屏情况,用户感知不到iframe页面在加载,体验效果不是很好。

解决方法:为了提升用户体验,让用户感知到当前页面在加载iframe,在iframe加载完成前添加loading效果,替代原有的白屏情况,样式大致如下图,可以参考element ui中的loading效果,Loading组件

具体代码实现:采用的技术栈是vue3+composition api,iframe中@load事件,在iframe页面加载完成后触发,即如下的handleIframeLoad函数。

 <div class="iframe-wrap">
    <loading v-if="isLoading"></loading>
    <iframe
        ref="iframeRef"
        class="iframe-wrap__iframe"
        allow="clipboard-read; clipboard-write"
        :src="iframeSrc"
        @load="handleIframeLoad"
    ></iframe>
</div>

通过isLoading变量变化来控制Loading图标是否展示。初始化定义isLoading变量为true,当iframe加载完成时,将isLoading变量置为false,在页面关闭函数中将isLoading变量再置为true。具体如下:

const isLoading = ref(true);
function handleIframeLoad() {
    isLoading.value = false;
}
function close() {
    isLoading.value = true;
}

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值