富文本编辑中一个非常关键的document属性execCommand(command,boole,val);这个属性可以得到并且编辑我们当前选则文档节点内容。
我们上一节讲过createRange和createTextRange,都是针对文档去创建并保存一个range选区,一般不会用来去做富文本编辑这种需求,而只是单纯的去做单个或者几个选取插入以及对光标处理效果;
不过后者可以利用document.selection.createTextRange().execCommand(a,b,c)去实现对选区编辑样式等。但是前者也就是w3c中并没有execCommand;所以实现起来就比较费劲
如果非得要用这两个去实现富文本也未必不可,因为两个方法中都有对选区的操作方法(我们可以对选区内容进行剪切后再编辑再复制原处)例如插入节点文本以及环绕选区等。
不过这种方式处理的就不能是单纯的像input框或者textArea这种文本输入节点了,因为所有设置都不会在里面显示,不过我们还是可以简单的针对其他p等标签进行删除插入样式等更为精细类似操作;此处不再赘述。
execCommand这个属性是针对选区进行操作的,例如:加粗、下划线、插入等。
不过由于w3c标准浏览器里面根本就没有execCommand这个属性,所以实现起来就没这个这么轻松易懂了。一般的富文本实现方法都会将编辑器放置于iframe中然后得到iframe的document对象,
最后利用该对象去得到execCommang属性从而达到我们富文本编辑效果。
具体应用介绍如下(来自互联网):
参数说明
command
类型:String
功能:要执行的命令的名称
boole
类型:boolean
功能:是否向用户显示命令特定的对话框或消息框。
val
类型:string
功能:要使用该命令分配的值。并非适用于所有命令。
所有属性:
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 清除当前选中区的选中状态。
其中各个浏览器都支持的有如下:
cut paste bold delete createLink fontName fontSize backColor foreColor formatBlockindent outdent insertHorizontalRule insertImage insertOrderedList
insertUnorderedList insertParagraph(有差异) italic justifyRight justifyCenter justifyLeft undo redo unlink(有差异) Underline SuperScript SelectAll