前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >利用iframe简单实现富文本效果

利用iframe简单实现富文本效果

作者头像
无道
发布2019-11-13 16:14:18
2K0
发布2019-11-13 16:14:18
举报
文章被收录于专栏:无道编程

前言

其实网上有很多富文本编辑器,诸如百度的ueditor,然后markdown编辑器github也有很多:

https://github.com/sparksuite/simplemde-markdown-editor

https://github.com/pandao/editor.md

百度那个不用说了,很古老的一个,很早没更新了,github这两个markdown编辑器,也有很多地方不满意,于是看了下原理。其实很简单。

原理

实现可视化编辑,主要有两种方法【或者说是两种方式】

1、designMode

2、contentEditable

contentEditable 刚开始在IE上实现,后来各大浏览器陆续支持contentEditable,HTML5标准也包含 contentEditable。

区别:

1、designMode 只能把 document整体改成可编辑状态。

2、contentEditable 可以把任何HTML元素改成可编辑状态 。

我们这里是利用designMode,然后再页面中嵌入一个iframe,将其designMode设置为on,这样就可以实现编辑。

代码语言:javascript
复制
<iframe name="editor" id="editor" frameborder="0"></iframe>

function enableDesign() {
    editor.document.designMode = "on";
}

然后利用execCommand执行各种命令达到加粗,加斜等效果。

代码语言:javascript
复制
function execCmd(command) {
    editor.document.execCommand(command, false, null);
}

更多命令,请看本文末附件。

截图

截图-1564808567
截图-1564808567

如图所示,只需要监听按钮点击事件,然后执行editor.document.execCommand(command, false, null);命令即可,就可以实现一般编辑器效果。

如果要编写markdown编辑器,同样的道理,只不过要通过正则等手段,将html标签替换成markdown格式的字符而已。

完整示例代码

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>富文本编辑器简单示例</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    <script src="https://cdn.bootcss.com/font-awesome/5.10.0-12/js/all.min.js"></script>
    <style>
        #editor {
            width: 1000px;
            height: 200px;
            border: 1px solid #ccc;
            overflow: auto;
            margin: 0 auto;
        }

        .btns {
            margin-bottom: .3rem;
        }

        .btns span {
            cursor: pointer;
        }
    </style>
</head>

<body onload="enableDesign();">
    <!-- <section name="" id="editor"></textarea> -->
    <div class="btns">
        <button onclick="execCmd('bold');"><i class="fa fa-bold"></i></button>
        <button onclick="execCmd('italic');"><i class="fas fa-italic"></i></button>
        <button onclick="execCmd('underline');"><i class="fas fa-underline"></i></button>
        <!-- <button onclick="execCmd('list');"><i class="fas fa-list"></i></button>
        <button onclick="execCmd('list-ol');"><i class="fas fa-list-ol"></i></button> -->
        <button onclick="getSource();">Source</button>
        <!-- <button onclick="getMarkdown();">M</button> -->
    </div>
    <iframe name="editor" id="editor" frameborder="0"></iframe>
</body>
<script>
    function enableDesign() {
        editor.document.designMode = "on";
    }
    function execCmd(command) {
        editor.document.execCommand(command, false, null);
    }
    let isSource = false;
    function getSource() {
        if (!isSource) {
            editor.document.body.textContent = editor.document.body.innerHTML;
            isSource = true;
        } else {
            editor.document.body.innerHTML = editor.document.body.textContent;
            isSource = false;
        }
    }

</script>

</html>

附:execCommand命令

代码语言:javascript
复制
1. 2D-Position 允许通过拖曳移动绝对定位的对象。  

2. AbsolutePosition 设定元素的 position 属性为“absolute”(绝对)。  

3. BackColor 设置或获取当前选中区的背景颜色。  

4. BlockDirLTR 目前尚未支持。  

5. BlockDirRTL 目前尚未支持。  

6. Bold 切换当前选中区的粗体显示与否。  

7. BrowseMode 目前尚未支持。  

8. Copy 将当前选中区复制到剪贴板。  

9. CreateBookmark 创建一个书签锚或获取当前选中区或插入点的书签锚的名称。  

10. CreateLink 在当前选中区上插入超级链接,或显示一个对话框允许用户指定要为当前选中区插入的超级链接的 URL。  

11. Cut 将当前选中区复制到剪贴板并删除之。  

12. Delete 删除当前选中区。  

13. DirLTR 目前尚未支持。  

14. DirRTL 目前尚未支持。  

15. EditMode 目前尚未支持。  

16. FontName 设置或获取当前选中区的字体。  

17. FontSize 设置或获取当前选中区的字体大小。  

18. ForeColor 设置或获取当前选中区的前景(文本)颜色。  

19. FormatBlock 设置当前块格式化标签。  

20. Indent 增加选中文本的缩进。  

21. InlineDirLTR 目前尚未支持。  

22. InlineDirRTL 目前尚未支持。  

23. InsertButton 用按钮控件覆盖当前选中区。  

24. InsertFieldset 用方框覆盖当前选中区。  

25. InsertHorizontalRule 用水平线覆盖当前选中区。  

26. InsertIFrame 用内嵌框架覆盖当前选中区。  

27. InsertImage 用图像覆盖当前选中区。  

28. InsertInputButton 用按钮控件覆盖当前选中区。  

29. InsertInputCheckbox 用复选框控件覆盖当前选中区。  

30. InsertInputFileUpload 用文件上载控件覆盖当前选中区。  

31. InsertInputHidden 插入隐藏控件覆盖当前选中区。  

32. InsertInputImage 用图像控件覆盖当前选中区。  

33. InsertInputPassword 用密码控件覆盖当前选中区。  

34. InsertInputRadio 用单选钮控件覆盖当前选中区。  

35. InsertInputReset 用重置控件覆盖当前选中区。  

36. InsertInputSubmit 用提交控件覆盖当前选中区。  

37. InsertInputText 用文本控件覆盖当前选中区。  

38. InsertMarquee 用空字幕覆盖当前选中区。  

39. InsertOrderedList 切换当前选中区是编号列表还是常规格式化块。  

40. InsertParagraph 用换行覆盖当前选中区。  

41. InsertSelectDropdown 用下拉框控件覆盖当前选中区。  

42. InsertSelectListbox 用列表框控件覆盖当前选中区。  

43. InsertTextArea 用多行文本输入控件覆盖当前选中区。  

44. InsertUnorderedList 切换当前选中区是项目符号列表还是常规格式化块。  

45. Italic 切换当前选中区斜体显示与否。  

46. JustifyCenter 将当前选中区在所在格式化块置中。  

47. JustifyFull 目前尚未支持。  

48. JustifyLeft 将当前选中区所在格式化块左对齐。  

49. JustifyNone 目前尚未支持。  

50. JustifyRight 将当前选中区所在格式化块右对齐。  

51. LiveResize 迫使 MSHTML 编辑器在缩放或移动过程中持续更新元素外观,而不是只在移动或缩放完成后更新。  

52. MultipleSelection 允许当用户按住 Shift 或 Ctrl 键时一次选中多于一个站点可选元素。  

53. Open 打开。  

54. Outdent 减少选中区所在格式化块的缩进。  

55. OverWrite 切换文本状态的插入和覆盖。  

56. Paste 用剪贴板内容覆盖当前选中区。  

57. PlayImage 目前尚未支持。  

58. Print 打开打印对话框以便用户可以打印当前页。  

59. Redo 重做。  

60. Refresh 刷新当前文档。  

61. RemoveFormat 从当前选中区中删除格式化标签。  

62. RemoveParaFormat 目前尚未支持。  

63. SaveAs 将当前 Web 页面保存为文件。  

64. SelectAll 选中整个文档。  

65. SizeToControl 目前尚未支持。  

66. SizeToControlHeight 目前尚未支持。  

67. SizeToControlWidth 目前尚未支持。  

68. Stop 停止。  

69. StopImage 目前尚未支持。  

70. StrikeThrough 目前尚未支持。  

71. Subscript 目前尚未支持。  

72. Superscript 目前尚未支持。  

73. UnBookmark 从当前选中区中删除全部书签。  

74. Underline 切换当前选中区的下划线显示与否。  

75. Undo 撤消。  

76. Unlink 从当前选中区中删除全部超级链接。  

77. Unselect 清除当前选中区的选中状态。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-08-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 原理
  • 截图
  • 完整示例代码
  • 附:execCommand命令
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档