Javascript 如何在HTML中实现富文本编辑器?
以下是演示:Javascript 如何在HTML中实现富文本编辑器?,javascript,web-applications,rich-text-editor,Javascript,Web Applications,Rich Text Editor,以下是演示: 当我使用Firebug检查源代码时,我看到它只是iFrame,但是iFrame怎么会有文本区行为呢??关于如何实现这一点有什么想法吗?感谢在中,在该框架中,您可以看到完整的HTML源代码,它构建了类似于文本区域+工具栏+内容的内容。一个复杂的Javascript正在完成背后的所有工作。例如,如果您选择一些文本并使用工具栏将其加粗,则脚本会在文本周围放置标记等等。使用它是最好的富编辑器。适用于任何浏览器,它有许多选项。它很容易使用。只需看看示例和文档。它包含在许多流行的博客和CMS
当我使用Firebug检查源代码时,我看到它只是iFrame,但是iFrame怎么会有文本区行为呢??关于如何实现这一点有什么想法吗?感谢在中,在该框架中,您可以看到完整的HTML源代码,它构建了类似于文本区域+工具栏+内容的内容。一个复杂的Javascript正在完成背后的所有工作。例如,如果您选择一些文本并使用工具栏将其加粗,则脚本会在文本周围放置
标记等等。使用它是最好的富编辑器。适用于任何浏览器,它有许多选项。它很容易使用。只需看看示例和文档。它包含在许多流行的博客和CMS中。因为我现在是为了工作而做的,所以我做了少量的研究。据我所知,有两种方法可以实现这一点:
document.designMode
在JavaScript中使用document.designMode
,将整个HTML文档设置为可编辑。由于整个HTML文档是可编辑的,因此可能需要一个iframe
来封装编辑,这样用户就不能编辑页面中任何不需要编辑的部分
据我所知,您链接的演示和TinyMCE使用了这种方法
内容可编辑
contenteditable
HTML属性类似,但不需要使用iframe
。将属性添加到标记中,其中的所有HTML都可以通过闪烁的光标进行编辑
下面是它的一个演示:
笔记
- 就我个人而言,我将在我的任务中查看
。以下是关于该主题的良好概述和详细信息:contenteditable
- 正如我所说,我在这方面做了有限的研究,因此请帮助我更正任何错误:)