关于MSHTML、IHTMLDocument、Ihtmldocument2-5的区别及 document.execCommand方法详解

网页操作 专栏收录该内容
1 篇文章 0 订阅

  1、关于MSHTML
  MSHTML是微软公司的一个COM组件,该组件封装了HTML语言中的所有元素及其属性,通过其提供的标准接口,可以访问指定网页的所有元素。
  MSHTML对象模型是由一些对象和集合组成的.处于根部的是HTML,描述了打开页面的1个窗口,包括一系列集合和对象。如Frames集合,History,Location,Navigator,Document,Vi—sum,Event对象等.其中描述呈现在客户窗口实际网页的是Document对象。由一系列的属性、方法、对象和集合组成。
  其中All集合中包含网页中所有标记(Tag)元素,其主要的方法和属性有:
  Length(长度):即标记出现的个数,可以把标记的集合理解为从0开始的一维数组,其次序按照标记在网页位置排列;
  Tags(标记):用于过滤出给定标记的集合,如Doc.Al1.Tags§得到所有分段标记P;
  Item(项目):用于选择集合中的某1个元素,如object.item(0)得到集合的第1个元素,而object.item(i)得到第i+1个元素.
  此外,IHTMLElement也是个常用的集合对象,代表网页中指定标记的集合,通过这个集合对象,可以得到网页上特定标记的内容。
  IHTMLElement有4个主要属性:
  InnerText:开始标记和结束标记之间的文本;
  InnerHTML:开始标记和结束标记之间的文本和HTML;
  OuterText:对象的文本;
  OuterHTML:对象的文本和HTML.
  2、IHTMLDocument、Ihtmldocument2-5的区别
  IHTMLDocument2-5 是 IHTMLDocument的一个高版本实现,它扩展基本的 IHTMLDocument COM 接口并定义某些新功能,如 IFrame 和 ExecVerb 等。可以认为支持3的对象肯定支持2,微软的东西一般是某个接口新加了方法,后面就加数字2、3、4什么的,以保证以前的接口不被修改,具体不同看MSHTML_TLB里的定义了。一般来说,用的比较多、浏览器兼容较好的是IHTMLDocument、Ihtmldocument2。

  3、Ihtmldocument2对象的 document.execCommand()方法。
  常用语法格式 如下:
   代码 :

 document.execCommand(sCommand[,交互方式, 动态参数 ]) 
 document.execCommand("2D-Position","false","true"); 

   其中:sCommand为指令参数(如下例中的"2D-Position"),交互方式参数如果是true的话将显示对话框,如果为false的话,则不显示对话框(下例中的"false"即表示不显示对话框),动态参数一般为一可用值或属性 值(如下例中的"true")。
   调用execCommand()可以实现浏览器菜单 的很多功能. 如保存文件 ,打开新文件,撤消、重做操作…等等. 有了这个方法,就可以很容易的实现网页中的文本编辑器.。如果灵活运用,可以很好的辅助我们完成各种项目。
   使用的例子如下:
〖全选〗命令的实现

document.execCommand("selectAll")

[说明]将选种网页中的全部内容!
[举例]在之间加入:

 <a href="#" onclick=document.execCommand("selectAll")>全选</a> 

〖打开〗命令的实现

document.execCommand("open")

[说明]这跟VB等编程设计中的web browser控件中的命令有些相似,大家也可依此琢磨琢磨。
[举例]在之间加入:

 <a href="#" onclick=document.execCommand("open")>打开</a>

〖另存为〗命令的实现

 document.execCommand("saveAs")

[说明]将该网页保存到本地盘的其它目录!
[举例]在之间加入:

 <a href="#" onclick=document.execCommand("saveAs")>另存为</a>

〖打印〗命令的实现

document.execCommand("print")

[说明]当然,你必须装了打印机!
[举例]在之间加入:

 <a href="#" onclick=document.execCommand("print")>打印</a>

Js代码 下面列出的是指令参数及意义

 //相当于单击文件中的打开按钮 
 document.execCommand("Open"); 
 //将当前页面 另存为 
 document.execCommand("SaveAs"); 
 //剪贴选中的文字到剪贴板; 
 document.execCommand("Cut","false",null); 
 //删除选中的文字; 
 document.execCommand("Delete","false",null); 
 //改变选中区域的字体; 
 document.execCommand("FontName","false",sFontName); 
 //改变选中区域的字体大小; 
 document.execCommand("FontSize","false",sSize|iSize); 
 //设置前景颜色; 
 document.execCommand("ForeColor","false",sColor); 
 //使绝对定位的对象可直接拖动; 
 document.execCommand("2D-Position","false","true"); 
 //使对象定位变成绝对定位; 
 68 document.execCommand("AbsolutePosition","false","true"); 
 //设置背景颜色; 
 document.execCommand("BackColor","false",sColor); 
 //使选中区域的文字加粗; 
 document.execCommand("Bold","false",null); 
 //复制选中的文字到剪贴板; 
 document.execCommand("Copy","false",null); 
 //设置指定锚点为书签; 
 document.execCommand("CreateBookmark","false",sAnchorName); 
 //将选中文 本变成超连接,若第二个参数为true,会出现参数设置对话框; 
 document.execCommand("CreateLink","false",sLinkURL); 
 //设置当前块的标签名; 
 document.execCommand("FormatBlock","false",sTagName);  

   document对象execCommand通常在IE中在线处理Html数据时非常有用,它可以让你轻而易举实现文字的加粗、加颜色、加字体等一系列的命令。

D-Position 允许通过拖曳移动绝对定位的对象。 
AbsolutePosition 设定元素的 position 属性为“absolute”(绝对)。 
BackColor 设置或获取当前选中区的背景颜色。 
BlockDirLTR 目前尚未支持。 
BlockDirRTL 目前尚未支持。 
Bold 切换当前选中区的粗体显示与否。 
BrowseMode 目前尚未支持。 
Copy 将当前选中区复制到剪贴板。 
CreateBookmark 创建一个书签锚或获取当前选中区或插入点的书签锚的名称。 
CreateLink 在当前选中区上插入超级链接,或显示一个对话框允许用户指定要为当前选中区插入的超级链接的 URL。 
Cut 将当前选中区复制到剪贴板并删除之。 
Delete 删除当前选中区。 
DirLTR 目前尚未支持。 
DirRTL 目前尚未支持。 
EditMode 目前尚未支持。 
FontName 设置或获取当前选中区的字体。 
FontSize 设置或获取当前选中区的字体大小。 
ForeColor 设置或获取当前选中区的前景(文本)颜色。 
FormatBlock 设置当前块格式化标签。 
Indent 增加选中文本的缩进。 
InlineDirLTR 目前尚未支持。 
InlineDirRTL 目前尚未支持。 
InsertButton 用按钮控件覆盖当前选中区。 
InsertFieldset 用方框覆盖当前选中区。 
InsertHorizontalRule 用水平线覆盖当前选中区。 
InsertIFrame 用内嵌框架覆盖当前选中区。 
InsertImage 用图像覆盖当前选中区。 
InsertInputButton 用按钮控件覆盖当前选中区。 
InsertInputCheckbox 用复选框控件覆盖当前选中区。 
InsertInputFileUpload 用文件上载控件覆盖当前选中区。 
InsertInputHidden 插入隐藏控件覆盖当前选中区。 
InsertInputImage 用图像控件覆盖当前选中区。 
InsertInputPassword 用密码控件覆盖当前选中区。 
InsertInputRadio 用单选钮控件覆盖当前选中区。 
InsertInputReset 用重置控件覆盖当前选中区。 
InsertInputSubmit 用提交控件覆盖当前选中区。 
InsertInputText 用文本控件覆盖当前选中区。 
InsertMarquee 用空字幕覆盖当前选中区。 
InsertOrderedList 切换当前选中区是编号列表还是常规格式化块。 
InsertParagraph 用换行覆盖当前选中区。 
InsertSelectDropdown 用下拉框控件覆盖当前选中区。 
InsertSelectListbox 用列表框控件覆盖当前选中区。 
InsertTextArea 用多行文本输入控件覆盖当前选中区。 
InsertUnorderedList 切换当前选中区是项目符号列表还是常规格式化块。 
Italic 切换当前选中区斜体显示与否。 
JustifyCenter 将当前选中区在所在格式化块置中。 
JustifyFull 目前尚未支持。 
JustifyLeft 将当前选中区所在格式化块左对齐。 
JustifyNone 目前尚未支持。 
JustifyRight 将当前选中区所在格式化块右对齐。 
LiveResize 迫使 MSHTML 编辑器在缩放或移动过程中持续更新元素外观,而不是只在移动或缩放完成后更新。 
MultipleSelection 允许当用户按住 Shift 或 Ctrl 键时一次选中多于一个站点可选元素。 
Open 目前尚未支持。 
Outdent 减少选中区所在格式化块的缩进。 
OverWrite 切换文本状态的插入和覆盖。 
Paste 用剪贴板内容覆盖当前选中区。 
PlayImage 目前尚未支持。 
Print 打开打印对话框以便用户可以打印当前页。 
Redo 目前尚未支持。 
Refresh 刷新当前文档。 
RemoveFormat 从当前选中区中删除格式化标签。 
RemoveParaFormat 目前尚未支持。 
SaveAs 将当前 Web 页面保存为文件。 
SelectAll 选中整个文档。 
SizeToControl 目前尚未支持。 
SizeToControlHeight 目前尚未支持。 
SizeToControlWidth 目前尚未支持。 
Stop 目前尚未支持。 
StopImage 目前尚未支持。 
StrikeThrough 目前尚未支持。 
Subscript 目前尚未支持。 
Superscript 目前尚未支持。 
UnBookmark 从当前选中区中删除全部书签。 
Underline 切换当前选中区的下划线显示与否。 
Undo 目前尚未支持。 
Unlink 从当前选中区中删除全部超级链接。 
Unselect 清除当前选中区的选中状态。

   关于document.execCommand:
   要执行编辑命令,可调用 document.execCommand,并传递对应于命令 ID 的字符串。另外还有可选的第二个参数 ,该参数指定如果可以应用的话是否显示此命令的用户界面。传递整数 1 将显示用户界面,整数 0 将跳过它。这个参数通常不用于编辑命令。因为默认值为 0,所以假如您没有使用第三个参数(在这种情况下,还必须为第二个参数传递值),一般可以不管它。第三个参数也是可选的, 在可应用的情况下,使用它来将任何所需参数传递给该命令。

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值