zoukankan      html  css  js  c++  java
  • 制作WEB在线编辑器插入HTML标签

    以前认为WEB的在线编辑器无非就是对输入内容的替换以及快捷的插入HTML代码,但是做的时候却发现虽然原理是那样,但是实现方法并非我想的那么死板。由于很少做UI上的东西所以到现在才知道在document中有execCommand方法可以解决插入HTML标签的问题,这个方法可以在光标所在位置插入需要的HTML标签,并且要注意的是,如果在一个限制的范围内插入标签需要先让该范围获得焦点,例如:
    a.focus();
    a.document.execCommand('insertButton','','btn');
    这里的a对象是一个iframe对象。 execcommand中的第一个参数是需要插入的控件的命令,第2个目前还不知道,第3个是ID名,这里将插入一个ID=btnBUTTON控件,如果想加入其他属性只需要接着后面写就行了,例如
    a.document.execCommand('insertButton','','btn class=btnclass color=red');
     
    第一个参数的详细列表
    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
    清除当前选中区的选中状态。
     
    另外,在当前鼠标所点的位置插入字符可用以下方法:
    <script>
    function showselect() {
    var oText = document.selection.createRange();
    oText.text=111;
    }
    </script>
    <body onmouseup="showselect()">
    <span id=span1>zdfzadfasfdasdfadsf</span>
     
     
  • 相关阅读:
    jQuery 在 IE 上 clone checkbox 的問題。
    C/C++ typedef用法
    C++继承
    map常用操作
    C++ JsonCpp 使用(含源码下载)
    string常用操作
    C++虚函数
    STL容器迭代过程中删除元素技巧(转)
    关于IE下用HTTPS无法下载/打开文件(转)
    C++STL概览
  • 原文地址:https://www.cnblogs.com/ZetaChow/p/2237426.html
Copyright © 2011-2022 走看看