博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
动态创建并访问网页元素
阅读量:5303 次
发布时间:2019-06-14

本文共 827 字,大约阅读时间需要 2 分钟。

最近在做OCX控件,但这个控件并不是一打开网页就需要初始化的,而是根据需要动态创建;在控件初始化的时候需要在控件内部获取其在网页中的DOM对象;并且创建之后需要立刻调用控件的方法。

最开始的方法如下:

1 var ctrl = document.createElement('object');2 ctrl.classid = 'CLSID:DCC16727-7A51-47B4-B38E-B020EAAF0584';3 document.body.appendChild(ctrl);

这个方法在IE11中什么问题都没有;但在IE9中,控件初始化时获取不到其在网页中的DOM对象。

通过测试,直接在页面中添加相应的HTML代码是可以在控件初始化的时候获取到其在网页中的DOM对象的。

ATL test page for object Test3

 

在网上搜了搜,搜到这么一篇文章《》,他的思路是在OCX中用insertAdjacentHTML方法创建。这个方法无法解决“控件初始化时获取不到其在网页中的DOM对象”这问题。

看了这篇文章的实现思路,让我想起了以前看的DOM的过桥、重排与重绘的概念(参考《》),调用getElementById会引起过桥,过桥会引起重排与重绘。

基于这个概念,于是就想通过innerHTML创建控件,是不是就跟一上来写好HTML代码是一样的。最终测试,这个方法可行。

最终代码如下:

var div = document.createElement('div');div.innerHTML = '';document.body.appendChild(div);ctrl = document.getElementById('Test4');

 

如何在控件初始化时获取其在网页中的DOM对象,可参考我的另一篇文章《》。

转载于:https://www.cnblogs.com/icedream/p/4804152.html

你可能感兴趣的文章
好用的性能检测工具 - Glances
查看>>
tcp滑动窗口和读写缓冲区
查看>>
GO 使用静态链接库编译 生成可执行文件 使用第三方 .a 文件,无源码构造
查看>>
ssh 使用指定网卡 连接特定网络
查看>>
鸿蒙操作系统发布会 分析 记录
查看>>
浅谈python 中正则的一些函数
查看>>
app生命周期之即将关闭
查看>>
MPU6050
查看>>
Asp.Net 加载不同项目程序集
查看>>
Jenkins插件--通知Notification
查看>>
思1-基本三观
查看>>
angularJS--apply() 和digest()方法
查看>>
Alpha 冲刺 (5/10)
查看>>
PHP函数之$_SERVER
查看>>
利用安装光盘创建本地yum源补装 RPM 软件包-通过命令行模式
查看>>
XML通過XSD產生CLASS
查看>>
跨线程调用窗体控件
查看>>
linq to sql 扩展方法
查看>>
241. Different Ways to Add Parentheses
查看>>
实验10 编写子程序 1.显示字符串
查看>>