加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angular – onLoad使用Iframe多次发生

发布时间:2020-12-17 17:02:36 所属栏目:安全 来源:网络整理
导读:在Angular 2中遇到一些问题,我正在创建一个具有iframe的组件并从输入中设置源.但是当它加载时,它会两次点击onLoad,一个用src =”,另一个用实际的输入url. 我似乎无法弄清楚当它被放入视图时如何将ifl挂钩为iframe. export class ExternalComponent implement
在Angular 2中遇到一些问题,我正在创建一个具有iframe的组件并从输入中设置源.但是当它加载时,它会两次点击onLoad,一个用src =”,另一个用实际的输入url.

我似乎无法弄清楚当它被放入视图时如何将ifl挂钩为iframe.

export class ExternalComponent implements OnInit {
    @Input()
    url: string;

    private src: any;

    constructor(private sanitizer: DomSanitizer) {

    }

    ngOnInit()    
    {
        this.src = this.sanitizer.bypassSecurityTrustResourceUrl(this.url)
    }

    onLoad() {

    }
}

HTML:

<iframe [src]="src" frameBorder="0" (load)="onLoad()"></iframe>

复制:http://plnkr.co/edit/Dnpmv6X2IO3WGQAg0372?p=preview

谢谢

解决方法

您可以尝试使用属性绑定,如果值为null,则根本不添加

<iframe [attr.src]="src ? src = null" frameBorder="0" (load)="onLoad()"></iframe>

更新

如https://stackoverflow.com/a/15880489/217408所述
当事件处理程序添加到< iframe>之前的元素时被添加到DOM中.这似乎是Angular正在做的事情.

在将元素添加到DOM后,必须添加事件处理程序

Plunker example

在url为null时忽略事件

Plunker example

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读