相信很多人都使用过多种富文本编辑器,富文本编辑器常用于编辑博客、用户交互,富文本编辑器分为两种:所见即所得和非所见即所得
两种富文本编辑器的实现原理是不相同的。
1. 非所见即所得编辑器
这种编辑器的实现原理很简单,用textarea元素就可以实现,假如要实现粗体、斜体、下划线、颜色字、图片的效果,只需在字的中间加上自定义标签即可,例如:
[b]富文本编辑器[b] ,[img]src=”http://www.google.com.hk/intl/zh-CN/images/logo_cn.png”[img]当然这些规则你得自己通过js进行定制。当POST提交后,再把这些标签转换为html标签。
2. 所见即所得编辑器
在1中我提到的几种效果,我们无法在textarea中见到立竿见影的效果(所见即所得),而文本域本身也只是支持一些字符的输入,并不支持显示html。
如何做到编辑像文本域,又能够即时所见呢?答案就是使用iframe作为内容编辑区域。iframe本身也是一个嵌套页面,它如何能够被编辑呢?这里有一些关键的属性,它们可以做到让iframe可以被编辑。
还是直接上代码来得方便一些,代码也很少。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
< html >
< script language = "javascript" type = "text/javascript" >
//初始化编辑器
function init() {
var ifr = document.getElementById("editor");
var doc = ifr.contentDocument || ifr.contentWindow.document; // W3C || IE
doc.designMode="on";
doc.contentEditable= true;
doc.write('< html >< head >< style >body{ margin:3px; word-wrap:break-word; word-break: break-all; }</ style ></ head >< body >GoodNessEditor</ body ></ html >');
alert(doc.body.innerHTML);
}
//设置选定的文本为粗体/正常
function setBold() {
var win=document.getElementById("editor").contentWindow;
win.document.execCommand("Bold",false,null);
win.focus();
}
</ script >
< p >
< input type = "button" id = "bBtn" value = "B" style = "font-weight:bold" onclick = "setBold();" />
</ p >
< p >
< iframe id = "editor" width = "600px" height = "400px" style = "border:solid 1px;" ></ iframe >
</ p >
< script type = "text/javascript" >
init();
</ script >
|
很重要的几点
(1). 用ifr.contentDocument ||
ifr.contentWindow.document方式获取iframe的文档对象
(2). 分别设置designMode属性为’on’,contentEditable属性为’true’让iframe可编辑
(3).
通过doc.body.innerHTML方法获取内容,这个内容是我们最终要插入到数据库或显示在页面上的(例如用户评论)
大家可以运行上面的代码,可以看到如下截图中的效果:
但是在实际运行的时候,你是否发现除了chrome浏览器外(用IETester, Firefox,
Chrome测试)打开这个页面都处于正在加载的状态(那个轮子转啊转,转个不停…)
只要在doc.write()方法前后加上doc.open(),
doc.close()就可以了(在写之前开启,写完之后关闭)。
最后,我们的Web程序中经常使用jQuery作为基础类库,那就把上面的代码也改造为jQuery吧。代码如下:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns = "http://www.w3.org/1999/xhtml" >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" />
< title >KF富文本编辑器</ title >
< script type = "text/javascript" src = "jquery.min.js" >
</ script >
< script type = "text/javascript" >
$(function(){
$d = $("#editor")[0].contentWindow.document; // IE、FF都兼容
$d.designMode="on";
$d.contentEditable= true;
$d.open();
$d.close();
$("body", $d).append("< div >A</ div >< div >B</ div >< div >C</ div >");
$('#insert_img').click(function(){
// 在iframe中插入一张图片
var img = '< img src = "' + $('#path').val() +'" />';
$("body", $d).append(img);
});
$('#preview').click(function(){
// 获取iframe的body内容,用于显示或者插入到数据库
alert($('#editor').contents().find('body').html());
$('#preview_area').html($('#editor').contents().find('body').html());
});
});
</ script >
</ head >
< body >
< p >< iframe id = "editor" width = "600px" height = "200px" style = "border:solid 1px;" ></ iframe ></ p >
< input type = "text" id = "path" value = "http://www.google.com.hk/intl/zh-CN/images/logo_cn.png" />
< input type = "button" id = "insert_img" value = "插入图片" />
< input type = "button" id = "preview" value = "预览" />
< p style = "border: 1px dashed #ccc;" id = "preview_area" ></ p >
</ body >
</ html >
|
效果图如下:
是不是觉得很简单呢?
分享到:
相关推荐
SQL Server 2008 R2是微软公司推出的一款企业级关系型数据库管理系统,它在SQL Server 2008的基础上进行了诸多改进和增强,旨在提供更高效、更安全的数据管理和分析能力。作为一款广泛应用于企业的数据库解决方案,...
首先,SQL Server 2008 R2在数据仓库方面有着显著提升,引入了列存储索引(Columnstore Indexes),这是一种专为快速数据分析设计的新型索引结构。通过列存储而非行存储,查询性能得到了大幅提升,使得大规模数据...
SQL Server 2008是微软公司推出的一款关系型数据库管理系统,它在企业级数据管理、分析和报告方面表现出色。这款教程适用于初学者,旨在帮助用户掌握SQL Server 2008的基础知识和核心功能。 一、SQL Server 2008...
SQL Server 2005是微软推出的一款关系型数据库管理系统,它在企业级数据管理和分析中扮演着重要的角色。这款产品引入了许多新特性和改进,为数据库开发人员和管理员提供了强大的工具集。以下是对SQL Server 2005脚本...
在SQL Server 2016中,数据库管理系统(DBMS)提供了一系列强大的功能,使得数据管理、查询和分析更为高效。这个"sql-server-2016-samples"压缩包包含的是针对SQL Server 2016的一系列示例脚本,是学习和理解SQL ...
**Microsoft SQL Server 2016** 是微软公司推出的一款关系型数据库管理系统(RDBMS),主要用于处理大量的数据存储和管理任务。SQL Server 2016是该系列的一个重要版本,它带来了许多创新功能和性能提升,旨在满足...
《SQL Server 2005代码大全》是针对SQL Server 2005数据库管理系统的一份详尽参考资料,旨在帮助数据库开发人员掌握SQL Server 2005的核心技术和最佳实践。这份大全涵盖了从基础查询到高级特性的各种代码示例,帮助...
本教程旨在帮助初学者从零开始学习如何管理和开发数据库,通过SQL Server 2012这一平台,掌握数据库的基础知识以及高级特性。 ### 1. SQL Server 2012概述 SQL Server 2012引入了许多新特性和改进,包括: - **...
描述中提到的数据库附加上SQL Server,意味着用户可以直接使用SQL Server管理工具连接数据库,无需额外的设置步骤。 数据库的用户名为"sa",这是SQL Server的默认系统管理员账户,全称为"System Administrator"。...
本思维导图旨在概述SQL Server的核心概念、功能和应用场景,帮助初学者和进阶者更好地理解和掌握这一系统。 一、SQL Server基础 SQL Server基于标准的SQL语言,包括SQL查询、插入、更新和删除等基本操作。此外,还...
SQL Server 2005是微软推出的一款强大的关系型数据库管理系统,它在数据存储、处理和分析方面提供了广泛的功能,适用于各种规模的企业。本教程旨在深入浅出地介绍SQL Server 2005的基础知识,帮助初学者快速掌握其...
Toad for SQL Server是一款强大的数据库管理和开发工具,专为SQL Server设计。这款6.1版本的免安装包意味着用户无需经过复杂繁琐的传统安装过程,只需下载单个文件即可开始使用。这种便携式版本尤其适合那些希望在...
SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在IT领域中扮演着重要的角色,尤其在企业级数据存储、管理和分析方面。本教程将深入探讨SQL Server 2005的主要特性、功能以及实际应用,旨在帮助学习者...
SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在IT行业中扮演着重要的角色,尤其在数据存储、管理和分析方面。本教程主要关注SQL Server 2005在数据库管理与开发中的应用。 一、SQL Server 2005...
SQL Server 2000是微软公司推出的一款关系型数据库管理系统,它在IT领域中扮演着重要的角色,尤其是在企业级数据存储和管理方面。这款产品提供了丰富的功能,包括数据存储、查询、分析以及数据安全等,是许多企业和...
在SQL Server 2005中,开发人员可以利用其高效的T-SQL语言进行复杂的数据操作,构建高效稳定的应用程序。 一、SQL Server 2005核心概念 1. 数据库引擎:这是SQL Server的核心组件,负责数据的存储、处理和安全。它...
3. **验证数据**:使用SQL Server 2005的兼容性模式在目标服务器上运行SQL Server 2000数据库,检查是否存在问题。 4. **升级数据库**:可以使用“数据库引擎升级顾问”来评估潜在问题,然后通过“数据库导入导出...
SQL Server 支持 Transact-SQL(T-SQL),这是一种用于管理 SQL Server 数据库的语言。为了确保SQL查询和命令能够被正确解析和执行,SQL Server 定义了一系列保留关键字。这些关键字在SQL语句中有特定的意义,不能...