深入理解javascript中的富文本编辑

前面的话

  一说起富文本,人们第一印象就是像使用word一样,在网页上操作文档。实际上差不多就是这样。富文本编辑,又称为WYSIWYG (What You See Is What You Get所见即所得),指在网页中编辑富文本内容。本文将详细介绍如何通过javascript实现富文本编辑

方式

  有两种编辑富文本的方式,一种是使用iframe元素,另一种是使用contenteditable属性

【1】iframe

  在页面中嵌入一个包含空HTML页面的iframe。通过设置designMode属性,这个空白的HTML页面可以被编辑,而编辑对象则是该页面<body>元素的HTML代码

  designMode属性有两个可能的值:"off"(默认值)和"on"。在设置为"on"时,整个文档都会变得可以编辑

  只有在页面完全加载之后才能设置designMode属性。因此,在包含页面中,需要使用onload事件处理程序

  [注意]此方法必须在服务器端才能执行,否则会提示跨域安全提示

<iframe name="wysiwyg" src="wysiwyg.html" style="height: 100px;width: 100px;"></iframe>
<script>
window.onload= function(){
    frames[‘wysiwyg‘].document.designMode = ‘on‘;
}
</script>

【2】contenteditable

  把contenteditable属性应用给页面中的任何元素,然后用户立即就可以编辑该元素

  设置document.designMode=‘on‘时,页面的任意位置都可以编辑;使用contenteditable=‘true‘则只对具体元素和其包含的元素起作用

  [注意]一定要区分contenteditable和contentEditable。contenteditable是元素的特性,而contentEditable是对象的属性

<div id="wysiwyg" style="height: 100px;width: 100px;border:1px solid black"></div>
<button id="btn1">打开富文本编辑</button>
<button id="btn2">关闭富文本编辑</button>
<script>
btn1.onclick = function(){wysiwyg.contentEditable = true;}
btn2.onclick = function(){wysiwyg.contentEditable = false;}
</script>

命令

  与富文本编辑器交互的主要方式,就是使用document.execCommand()。这个方法可以对文档执行预定义的命令,而且可以应用大多数格式

  document.execCommand(String aCommandName, Boolean aShowDefaultUI, String aValueArgument)方法需要传递3个参数

  aCommandName表示要执行的命令名称,不可省略

  aShowDefaultUI表示是否展示用户界面,默认为false,可省略

  aValueArgument表示额外参数值,默认为null,可省略

  [注意]为了确保浏览器兼容性,第二个参数应始终设置为false,因为firefox在该参数为true时抛出错误

段落格式

居中          document.execCommand(‘justifyCenter‘);
左对齐        document.execCommand(‘justifyLeft‘);
右对齐         document.execCommand(‘justifyRight‘);
添加缩进      document.execCommand(‘indent‘);
去掉缩进      document.execCommand(‘outdent‘);
<div id="wysiwyg" style="height: 100px;width: 300px;border:1px solid black" contenteditable>测试内容</div>
<button data-name="justifyCenter">居中</button>
<button data-name="justifyLeft">左对齐</button>
<button data-name="justifyRight">右对齐</button>
<button data-name="indent">添加缩进</button>
<button data-name="outdent">去掉缩进</button>
<script>
var btns = document.getElementsByTagName(‘button‘);
for(var i = 0; i < btns.length; i++){
    btns[i].onclick = function(){
        document.execCommand(this.getAttribute(‘data-name‘));
    }
}
</script>

文本格式

字体类型      document.execCommand(‘fontname‘,false,sFontName)
字体大小      document.execCommand(‘fontsize‘,false,sFontSize)
字体颜色      document.execCommand(‘forecolor‘,false,sFontColor)
背景色         document.execCommand(‘backColor‘,false,sBackColor)
加粗          document.execCommand(‘bold‘);
斜体          document.execCommand(‘italic‘);
下划线         document.execCommand(‘underline‘);
<div id="wysiwyg" style="height: 100px;width: 300px;border:1px solid black" contenteditable>测试内容</div>
<button data-name="fontname" data-value="宋体">宋体</button>
<button data-name="fontsize" data-value="5">大字体</button>
<button data-name="forecolor" data-value="red">红色字体</button>
<button data-name="backColor" data-value="lightgreen">浅绿背景</button>
<button data-name="bold">加粗</button>
<button data-name="italic">斜体</button>
<button data-name="underline">下划线</button>
<script>
var btns = document.getElementsByTagName(‘button‘);
for(var i = 0; i < btns.length; i++){
    btns[i].onclick = function(){
        document.execCommand(this.getAttribute(‘data-name‘),false,this.getAttribute(‘data-value‘));
    }
}
</script>

编辑

复制          document.execCommand(‘copy‘);
剪切          document.execCommand(‘cut‘);
粘贴          document.execCommand(‘paste‘);(经测试无效)
全选          document.execCommand(‘selectAll‘);
删除          document.execCommand(‘delete‘);
后删除         document.execCommand(‘forwarddelete‘);
清空格式      document.execCommand(‘removeFormat‘);
前进一步      document.execCommand(‘redo‘);
后退一步      document.execCommand(‘undo‘);
打印          document.execCommand(‘print‘);(对firefox无效)
<div id="wysiwyg" style="height: 100px;width: 300px;border:1px solid black" contenteditable>测试内容</div>
<button data-name="copy">复制</button>
<button data-name="cut">剪切</button>
<button data-name="paste">粘贴</button>
<button data-name="selectAll">全选</button>
<button data-name="delete">删除</button>
<button data-name="forwarddelete">后删除</button>
<button data-name="removeFormat">清空格式</button>
<button data-name="redo">前进一步</button>
<button data-name="undo">后退一步</button>
<button data-name="print">打印</button>
<script>
var btns = document.getElementsByTagName(‘button‘);
for(var i = 0; i < btns.length; i++){
    btns[i].onclick = function(){
        document.execCommand(this.getAttribute(‘data-name‘));
    }
}
</script>

插入

插入标签       document.execCommand(‘formatblock‘,false,elementName);
插入<hr>      document.execCommand(‘inserthorizontalrule‘);
插入<ol>      document.execCommand(‘insertorderedlist‘);
插入<ul>      document.execCommand(‘insertunorderedlist‘);
插入<p>        document.execCommand(‘insertparagraph‘);
插入图像      document.execCommand(‘insertimage‘,false,URL);
增加链接      document.execCommand(‘createlink‘,false,URL);
删除链接      document.execCommand(‘unlink‘);
<div id="wysiwyg" style="height: 100px;width: 300px;border:1px solid black;overflow:auto" contenteditable>测试内容</div>
<button data-name="formatblock" data-value="div">插入div</button>
<button data-name="inserthorizontalrule">插入hr</button>
<button data-name="insertorderedlist">插入ol</button>
<button data-name="insertunorderedlist">插入ul</button>
<button data-name="insertparagraph">插入p</button>
<button data-name="insertimage" data-value="http://files.cnblogs.com/files/xiaohuochai/zan.gif">插入图像</button>
<button data-name="createlink" data-value="www.cnblogs.com/xiaohuochai">增加链接</button>
<button data-name="unlink">删除链接</button>
<script>
var btns = document.getElementsByTagName(‘button‘);
for(var i = 0; i < btns.length; i++){
    btns[i].onclick = function(){
        document.execCommand(this.getAttribute(‘data-name‘),false,this.getAttribute(‘data-value‘));
    }
}
</script>

最后

  实现一个富文本编辑器,看似容易,但实际上是一个大工程

  给大家推荐几款不错的在线富文本编辑器

  widgEditor

  wangeditor

  ueditor

  欢迎交流

时间: 2025-01-11 13:54:25

深入理解javascript中的富文本编辑的相关文章

javascript中的富文本编辑

一说起富文本,人们第一印象就是像使用word一样,在网页上操作文档.实际上差不多就是这样.富文本编辑,又称为WYSIWYG (What You See Is What You Get所见即所得),指在网页中编辑富文本内容.本文将详细介绍如何通过javascript实现富文本编辑 方式 有两种编辑富文本的方式,一种是使用iframe元素,另一种是使用contenteditable属性 [1]iframe 在页面中嵌入一个包含空HTML页面的iframe.通过设置designMode属性,这个空白的

深入理解JavaScript中创建对象模式的演变(原型)

创建对象的模式多种多样,但是各种模式又有怎样的利弊呢?有没有一种最为完美的模式呢?下面我将就以下几个方面来分析创建对象的几种模式: Object构造函数和对象字面量方法 工厂模式 自定义构造函数模式 原型模式 组合使用自定义构造函数模式和原型模式 动态原型模式.寄生构造函数模式.稳妥构造函数模式 第一部分:Object构造函数和对象字面量方法 我之前在博文<javascript中对象字面量的理解>中讲到过这两种方法,如何大家不熟悉,可以点进去看一看回顾一下.它们的优点是用来创建单个的对象非常方

深入理解JavaScript中的属性和特性

深入理解JavaScript中的属性和特性? JavaScript中属性和特性是完全不同的两个概念,这里我将根据自己所学,来深入理解JavaScript中的属性和特性. 主要内容如下: 理解JavaScript中理解对象的本质.理解对象与类的关系.对象与引用类型的关系 对象属性如何进行分类 属性中特性的理解 第一部分:理解JavaScript中理解对象的本质.理解对象与类的关系.对象与引用类型的关系 对象的本质:ECMA-262把对象定义为:无序属性的集合,其属性可以包含基本值.对象或者函数.即

【干货理解】理解javascript中实现MVC的原理

理解javascript中的MVC MVC模式是软件工程中一种软件架构模式,一般把软件模式分为三部分,模型(Model)+视图(View)+控制器(Controller); 模型:模型用于封装与应用程序的业务逻辑相关的数据以及对数据处理的方法.模型有对数据直接访问的权利.模型不依赖 "视图" 和 "控制器", 也就是说 模型它不关心页面如何显示及如何被操作. 视图:视图层最主要的是监听模型层上的数据改变,并且实时的更新html页面.当然也包括一些事件的注册或者aja

JavaScript大杂烩6 - 理解JavaScript中的this

在JavaScript开发中,this是很常用的一个关键字,但同时也是一个很容易引入bug的一个关键字,在这里我们就专门总结一下页面中可能出现的this关键字(包括几种在其他页面文件中出现的this). JavaScript中的this关键字通常只使用在函数中,它指向当前函数的调用者,这是this关键字的本质,所有的使用方式都是围绕这个展开的,让我们来看一下在各种性质的函数中this的用法.1. 在对象的函数中使用this var person = { name: 'Frank', say: f

全面理解Javascript中Promise

全面理解Javascript中Promise 最近在学习Promise的时候,在网上收集了一些资料,发现很多的知识点不够系统,所以小编特意为大家整理了一些自认为 比较好的文章,供大家更好地学习js中非常有趣的Promise Promise概念 2015 年 6 月,ECMAScript 6 的正式版 终于发布了. ECMAScript 是 JavaScript 语言的国际标准,javascript 是 ECMAScript 的实现.ES6 的目标,是使得 JavaScript 语言可以用来编写大

转载 深入理解JavaScript中的this关键字

转载原地址: http://www.cnblogs.com/rainman/archive/2009/05/03/1448392.html 深入理解JavaScript中的this关键字 1. 一般用处 2. this.x 与 apply().call() 3. 无意义(诡异)的this用处 4. 事件监听函数中的this 5. 总结 在JavaScript中this变量是一个令人难以摸清的关键字,this可谓是非常强大,充分了解this的相关知识有助于我们在编写面向对象的JavaScript程

js架构设计模式——理解javascript中的MVVM开发模式

理解javascript中的MVVM开发模式 http://blog.csdn.net/slalx/article/details/7856769 MVVM的全称是Model View ViewModel,这种架构模式最初是由微软的MartinFowler作为微软软件的展现层设计模式的规范提出,它是MVC模式的衍生物,MVVM模式的关注点在能够支持事件驱动的UI开发平台,例如HTML5,[2][3] WindowsPresentation Foundation (WPF), Silverligh

理解javascript中的回调函数(callback)【转】

在JavaScrip中,function是内置的类对象,也就是说它是一种类型的对象,可以和其它String.Array.Number.Object类的对象一样用于内置对象的管理.因为function实际上是一种对象,它可以"存储在变量中,通过参数传递给(别一个)函数(function),在函数内部创建,从函数中返回结果值". 因为function是内置对象,我们可以将它作为参数传递给另一个函数,延迟到函数中执行,甚至执行后将它返回.这是在JavaScript中使用回调函数的精髓.本篇文