`

JS中document.execCommand()的用法

 
阅读更多

document.execCommand()方法处理Html数据时常用语法格式如下:

document.execCommand(sCommand[,交互方式, 动态参数])

 

其中:sCommand为指令参数(如下例中的”2D-Position”),交互方式参数如果是true的话将显示对话框,如果为false的话,则不显示对话框(下例中的”false”即表示不显示对话框),动态参数一般为一可用值或属性值(如下例中的”true”)。

 

document.execCommand(”2D-Position”,”false”,”true”);

 

调用execCommand()可以实现浏览器菜单的很多功能. 如保存文件,打开新文件,撤消、重做操作…等等. 有了这个方法,就可以很容易的实现网页中的文本编辑器.

 

如果灵活运用,可以很好的辅助我们完成各种项目.

 

使用的例子如下:

 

1、〖全选〗命令的实现

[格式]:document.execCommand(”selectAll”)

[说明]将选种网页中的全部内容!

[举例]在之间加入:

全选

 

2、〖打开〗命令的实现

[格式]:document.execCommand(”open”)

[说明]这跟VB等编程设计中的webbrowser控件中的命令有些相似,大家也可依此琢磨琢磨。

[举例]在之间加入:

打开

 

3、〖另存为〗命令的实现

[格式]:document.execCommand(”saveAs”)

[说明]将该网页保存到本地盘的其它目录!

[举例]在之间加入:

另存为

 

4、〖打印〗命令的实现

[格式]:document.execCommand(”print”)

[说明]当然,你必须装了打印机!

[举例]在之间加入:

打印

 

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”);

 

//使对象定位变成绝对定位;

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(”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”);

 

//使对象定位变成绝对定位;

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,所以假如您没有使用第三个参数(在这种情况下,还必须为第二个参数传递值),一般可以不管它。第三个参数也是可选的,在可应用的情况下,使用它来将任何所需参数传递给该命令。

 

Pixy方法受到IE的cache bug影响会闪烁。其实并没有说清楚这个问题,但其实该bug是有条件的,即IE的cache设置为Every visit to the page,而不是默认的Automatically。基本上,只有开发者才会把cache设置为每次访问检查更新,所以这个bug其实不会影响真正的用户(根据在winxpsp2的ie6下测试,虽然可能仍然调用了一次网络存取的api,但是并没有发生实际的请求,症状就是鼠标有极短时间的抖动,但是图像不会闪烁)。此外有人发现了一个未公开的方法来让IE对背景图进行缓存:

document.execCommand(”BackgroundImageCache”,false,true)

 

用这种方法甚至避免了api调用,貌似是直接缓存在IE内存中。

 

IE6下设置背景图片是不会被真正cache住的,就算服务器做了cache,如果想cache住只能~~~

 

做过UI设计和开发的人一定知道,IE(不包括IE7)会经常从服务器端重新载入背景图片,好端端的UI界面在IE(不包括IE7)中就这样被折腾着……

 

Erik发现了一个简单的解决办法(针对IE7以下的IE有效,其实在IE7中已经修复了这个Bug)

程序代码 程序代码

 

document.execCommand(”BackgroundImageCache”, false, true);

 

 

今天阅读Ext的源码时发现Jack Slocum已经考虑到了这一点,在Ext.js中给出了他的实现,在其它Ajax框架中应该还没有这种类似的代码,从这一个细节上就能看出Ext的全面~

程序代码 程序代码

 

var isIE = ua.indexOf(”msie”) > -1, isIE7 = ua.indexOf(”msie 7″) > -1;

// remove css image flicker

if(isIE && !isIE7){

try{

document.execCommand(”BackgroundImageCache”, false, true);

}catch(e){}

}

 

 

今天阅读幻宇的dreamplayer播放器源码时发现幻宇也针对IE的背景缓存进行了修复,只是他并没考虑到IE7中已经不存在这个现象了,这是 evml.js中的一段相关代码~(顺便嘀咕两句:这家伙,写JS从来不加分号的,以前是这样,现在还是这样,这样的话怎么进行压缩呀,汗~下面的代码按照我的习惯都已加上分号,哪怕只有两三句而已~)

程序代码 程序代码

 

windows.isIE=navigator.appName.indexOf("Microsoft")==0;

if(isIE){

document.documentElement.addBehavior("#default#userdata");

document.execCommand("BackgroundImageCache",false,true); 

分享到:
评论

相关推荐

    document.execCommand()的用法

    此方法在早期的Web开发中被广泛使用,特别是在富文本编辑器中,因为它提供了一种简便的方式来操作文档内容而无需编写复杂的JavaScript代码或调用其他库。 #### 语法 ```javascript document.execCommand(command, ...

    html中的内容直接下载到excel中,替换 document.execCommand(‘saveAs’)方法

    传统的做法是使用`document.execCommand('saveAs')`方法,但这个方法在某些现代浏览器中已被废弃,因此需要寻找替代方案。本篇文章将详细探讨如何在不依赖`execCommand('saveAs')`的情况下,实现HTML内容直接下载到...

    IE图片缓存document.execCommand("BackgroundImageCache",false,true)

    此外,DreamPlayer播放器的作者幻宇也在其源码evml.js中使用了类似的方法来处理IE的背景图片缓存问题,不过没有针对IE7以上的兼容性处理: ```javascript window.isIE = navigator.appName.indexOf("Microsoft") ==...

    【JavaScript源代码】js实现复制粘贴的两种方法.docx

    为了提升用户体验并简化操作流程,本文将介绍两种使用JavaScript实现复制功能的方法,并针对每种方法提供详细的代码示例与解析。 #### 二、方法 在本文中,我们将探讨两种实现复制功能的技术方案。尽管这两种方法都...

    javascript document.execCommand() 常用解析

    在HTML5中,这种方式不再推荐使用,但对于旧版本的浏览器仍有必要了解这些命令的使用方法。 `document.execCommand()`命令执行时,通常需要文档处于可编辑状态(`document.designMode = 'on'`),或者文档中某部分...

    JS实现复制功能

    标题中的“JS实现复制功能”指的是使用JavaScript编程语言来实现在网页上复制文本的功能。这一功能常见于用户界面,允许用户快速便捷地复制文本内容,如URL、代码片段或者重要的信息,而无需手动选中并复制。在描述...

    javascript-document对象详解(下).zip

    JavaScript中的`document`对象是浏览器提供的一个全局对象,它代表了HTML或XML文档的结构,并提供了与页面交互的各种方法和属性。在这个“javascript-document对象详解(下)”的压缩包中,我们可以通过三个文件来深入...

    input按钮onclick事件大全

    这些操作主要适用于IE浏览器,因为`document.all`是IE特有的属性,并且`ExecWB`方法也是IE专有的。 #### 2. 页面刷新 - **`window.location.reload()`**:这行代码用于重新加载当前页面。这对于用户想要更新页面...

    在JavaScript中如何解决用execCommand(

    在Web开发中,经常需要实现将页面中的内容保存到用户的本地设备上的功能,这通常可以通过JavaScript中的execCommand命令实现,特别是使用"SaveAs"命令。然而,由于浏览器的兼容性问题,这种方法并不总是有效的。在IE...

    html中js点击一键复制功能,兼容各大浏览器

    `document.execCommand()`已经过时,但仍然在一些老版本的浏览器中支持,而`navigator.clipboard.writeText()`是更现代且推荐的方法,它符合W3C的标准。 1. **使用`document.execCommand()`** 这个方法在过去被...

    JS粘贴文本到剪贴板

    在JavaScript(JS)中,将文本复制到剪贴板的操作是一项常见的需求,特别是在网页交互和富文本编辑器中。这个任务涉及到浏览器兼容性问题,因为不同的浏览器可能支持不同的API或方法来实现这一功能。本文将深入探讨...

    JSP调用ie菜单命令

    通过以上介绍,我们可以了解到`document.execCommand`方法在早期网页开发中的应用非常广泛,它为开发者提供了强大的功能来增强用户体验。然而,在现代浏览器环境中,这种方法的使用受到了限制,开发者应该寻求更现代...

    js复制文本(文本框、隐藏域、选择文本)

    在JavaScript(JS)中,复制文本是一项常见的需求,无论是在文本框、隐藏域还是用户选中的文本上。这里我们将深入探讨如何使用JavaScript实现这些功能。 首先,让我们关注文本框(`<input type="text">` 或 `...

    cument.execCommand()用法深入理解

    总的来说,`document.execCommand()`是一个方便的JavaScript工具,用于在浏览器中实现基本的文本编辑功能。然而,随着Web技术的发展,开发者应关注新的API和最佳实践,以提供更稳定、更现代的用户体验。

    Javascript代码实现浏览器菜单命令.doc

    使用 document.execCommand("selectAll") 可以实现全选命令,该命令可以选种当前网页中的全部内容。 示例代码:<a href="#" onclick=document.execCommand("selectAll")>全选 三、查看菜单命令的实现 1. 刷新命令...

    网页制作必备(最常用javascript onclick语句40条)

    网页制作过程中,JavaScript 的 onclick 事件处理程序是实现用户交互的关键技术之一。下面将详细介绍给定文件中提及的40条最常用的 JavaScript onclick 语句,帮助网页开发者更好地理解和运用这些代码片段。 ### 1....

    用javascript做的文本编辑器

    ### 二、JavaScript中的`document.execCommand()`方法 `document.execCommand()`是浏览器提供的一种用于执行常见的编辑命令的方法,这些命令通常可以在浏览器的标准上下文菜单中找到。此方法可以实现如复制、粘贴、...

    常用js代码大全.pdf

    这些是JavaScript编程中的一些常见用法,掌握它们能帮助开发者更好地构建交互性和动态性的Web页面。不过,随着浏览器的更新和Web标准的发展,推荐使用更现代的方法,如事件监听器(`addEventListener` 和 `...

    javascript实现将文件保存到本地方法汇总

    具体来说,这些函数都是在某种触发事件(如点击事件)之后执行,通过创建一个临时的弹出窗口(使用window.open方法)并在该窗口中执行保存操作(使用document.execCommand("SaveAs")命令)。该方法依赖于浏览器支持...

    excCommand命令

    `execCommand` 是一个在早期浏览器中广泛使用的非标准 JavaScript 方法,主要用于实现富文本编辑器的功能。通过调用 `document.execCommand`,开发者能够轻松地执行一系列与编辑文档相关的操作,如格式化文本、插入...

Global site tag (gtag.js) - Google Analytics