javascript和多媒体编辑器的实现
Iframe元素(IE4+和NN6中)允许HTML内容从一个独立的源载入另一个文档实体。在某种程度上,NN4IAYER元素是Iframe概念的先驱,但是与LAYER不同的是,Iframe元素不是本来就可定位的,它可以保其他的NTML元素一样,通过将定位属性指定为与Iframe相关联的样式表来定位。如果没有明确地定位,Iframe元素将以正常的源代码顺序显示在文档的实体中。不像框架集的框架,Iframe可以随意放置在任何文档的内部。如果Iframe在脚本控制下改变大小.周围的内容将会移出或者紧缩。
多媒体编辑器的实现要借助于Iframe对象。通过Javascript对对象Iframe的控制来实现多媒体编辑器的各种功能。
一、Iframe的访问方式:
window.frames[i]
window.frames["framename"]
二、属性:
1、document
可以把document属性作为到弹出宙口的通道,这个属性是创建脚本到弹出窗口惟一的访问点。大多数这个属性的应用程序设置document属性,以此来控制Iframe窗口中的内容。
例:myPopup.document.style.border= "solid 3px gray";
2、isOpen
返回当前的Iframe窗口是否可见。
三、多媒体编辑器的实现
要实现多媒体编辑器,首先应把Iframe的document的designMode设为"on",格式如下:
MyTitle.document.designMode = "on";
MyTitle.document.open();
MyTitle.document.write("<body leftmargin=/"5/" rightmargin=/"5/" bottommargin=/"5/" topmargin=/"5/" style=/"font-size:12px/"></body>");
MyTitle.document.close();
实现多媒体编辑器,是借助于document对象的execCommand()函数,即:document.execCommand(CommandName[,true | false[,other]])函数原型定的比较草,其中第一个参数是用来指定属性名称的,第二个参数一般设为false即可,它是用来指定浏览器是否缓存数据,第三个参数对不同的属性有不同的含义。
这个函数可用的参数比较多,现列举如下:
2D-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 清除当前选中区的选中状态。
由于参数较多,这里就不一一举例了,常用到的举例如下:
<iframe id="MyTitle" width="600" height="400"></iframe>
//复制
function docopy()
{
MyTitle.focus();
MyTitle.document.execCommand("Copy ");
/*实现复制,其中的参数Copy不区分大小写。也可以把这个参数换成Cut,Paste,Delete,JustifyLeft,JustifyCenter,JustifyRight,Bold,Italic,Underline,InsertImage等,这些属性可在上面的属性列表中查找到*/
MyTitle.focus();
}
//另存为
function SaveAs(){
MyTitle.document.execCommand('SaveAs',false,'mycodes.txt');
}
//将选中的区块重设为一个相应的物件
/*
******************************************
* 以下指令都是为选中的区块重设一个object;
* 如没有特殊说明,第二个参数true或false是一样的;
* 参数三表示为该object的id;
* 可以用在javascript中通过其指定的id来控制它
******************************************
*/
/*重设为一个button(InsertButton和InsertInputButtong一样,
只不前者是button,后者是input)*/
MyTitle.document.execCommand('InsertButton',false,"mybutton"); //true或false无效
MyTitle.document.execCommand('InsertFieldSet',true,"myFielt");
//插入一个水平线
MyTitle.document.execCommand('InsertHorizontalRule',true,"myline");
//插入一个iframe
MyTitle.document.execCommand('InsertIFrame',true,"myFrame");
//插入一个InsertImage,设为true时需要图片,false时不需图片
MyTitle.document.execCommand('InsertImage',false,"myPic");
//插入一个checkbox
MyTitle.document.execCommand('InsertInputCheckbox',true,"myCheckBox");
//插入一个file类型的object
MyTitle.document.execCommand('InsertInputFileUpload',false,"myFile");
//插入一个hidden
MyTitle.document.execCommand('InsertInputHidden',false,"myHidden");
//插入一个InputImage
MyTitle.document.execCommand('InsertInputImage',false,"myPutImage");
//插入一个Password
MyTitle.document.execCommand('InsertInputPassword',true,"myPass");
//插入一个Radio
//document.execCommand('InsertInputRadio',false,"myRadio");
//插入一个Reset
MyTitle.document.execCommand('InsertInputReset',true,"myReset");
//插入一个Submit
MyTitle.document.execCommand('InsertInputSubmit',false,"mySubmit");
//插入一个input text
MyTitle.document.execCommand('InsertInputText',false,"myInputText");
//插入一个textarea
MyTitle.document.execCommand('InsertTextArea',true,"myTextarea");
//.插入一个 select list box
MyTitle.document.execCommand('InsertSelectListbox',false,"mySelectList");
//插入一个single select
MyTitle.document.execCommand('InsertSelectDropdown',true,"myDropdown");
//插入一个line break(硬回车??)
MyTitle.document.execCommand('InsertParagraph');
//插入一个marquee
MyTitle.document.execCommand('InsertMarquee',true,"myMa");
//用于取消选中的阴影部分
MyTitle.document.execCommand('Unselect');
//选中页面上的所有元素
MyTitle.document.execCommand('SelectAll');
}
/*
*该function用来将页面保存为一个文件
*/
function SaveAs()
{
//第二个参数为欲保存的文件名
MyTitle.document.execCommand('SaveAs','mycodes.txt');
//打印整个页面
MyTitle.document.execCommand('print');
}
如果要在编辑器中插入Html编码,应该使用如下代码实现:
var reStr="<a href='space.msn.com/xuanxingmin' target='_blank'>Create by xuanxingmin@20060425</a>"
MyTitle.document.body.innerHTML += reStr;