`
ruilin215
  • 浏览: 1148140 次
  • 性别: Icon_minigender_2
  • 来自: 成都
文章分类
社区版块
存档分类
最新评论

在SQL Server中,索引是一种增强式的存在,这意味着,即使没有索引,SQL Server仍然可以实现应有的功能。但索引可以在大多数情况下大大提升查询性能,

 
阅读更多

相信很多人都使用过多种富文本编辑器,富文本编辑器常用于编辑博客、用户交互,富文本编辑器分为两种:所见即所得和非所见即所得

两种富文本编辑器的实现原理是不相同的。

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方法获取内容,这个内容是我们最终要插入到数据库或显示在页面上的(例如用户评论)

大家可以运行上面的代码,可以看到如下截图中的效果:

 

image

但是在实际运行的时候,你是否发现除了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>

效果图如下:

image

是不是觉得很简单呢?

1
2
分享到:
评论
1 楼 John_Kong19 2011-12-23  
莫非现在文章题目和内容不一样是种流行吗

相关推荐

    英文版SQL server2008R2.zip

    SQL Server 2008 R2是微软公司推出的一款企业级关系型数据库管理系统,它在SQL Server 2008的基础上进行了诸多改进和增强,旨在提供更高效、更安全的数据管理和分析能力。作为一款广泛应用于企业的数据库解决方案,...

    SQL Server 2008 R2 UNLEASHED

    首先,SQL Server 2008 R2在数据仓库方面有着显著提升,引入了列存储索引(Columnstore Indexes),这是一种专为快速数据分析设计的新型索引结构。通过列存储而非行存储,查询性能得到了大幅提升,使得大规模数据...

    sql server2008文档教程

    SQL Server 2008是微软公司推出的一款关系型数据库管理系统,它在企业级数据管理、分析和报告方面表现出色。这款教程适用于初学者,旨在帮助用户掌握SQL Server 2008的基础知识和核心功能。 一、SQL Server 2008...

    sql server 2005脚本

    SQL Server 2005是微软推出的一款关系型数据库管理系统,它在企业级数据管理和分析中扮演着重要的角色。这款产品引入了许多新特性和改进,为数据库开发人员和管理员提供了强大的工具集。以下是对SQL Server 2005脚本...

    sql-server-2016-samples,SQL SERVER 2016 脚本例子

    在SQL Server 2016中,数据库管理系统(DBMS)提供了一系列强大的功能,使得数据管理、查询和分析更为高效。这个"sql-server-2016-samples"压缩包包含的是针对SQL Server 2016的一系列示例脚本,是学习和理解SQL ...

    Microsoft SQL Server 2016简介.zip

    **Microsoft SQL Server 2016** 是微软公司推出的一款关系型数据库管理系统(RDBMS),主要用于处理大量的数据存储和管理任务。SQL Server 2016是该系列的一个重要版本,它带来了许多创新功能和性能提升,旨在满足...

    SQL Server 2005代码大全

    《SQL Server 2005代码大全》是针对SQL Server 2005数据库管理系统的一份详尽参考资料,旨在帮助数据库开发人员掌握SQL Server 2005的核心技术和最佳实践。这份大全涵盖了从基础查询到高级特性的各种代码示例,帮助...

    SQL server2012 教程

    本教程旨在帮助初学者从零开始学习如何管理和开发数据库,通过SQL Server 2012这一平台,掌握数据库的基础知识以及高级特性。 ### 1. SQL Server 2012概述 SQL Server 2012引入了许多新特性和改进,包括: - **...

    图书管理系统(jsp+sql server)

    描述中提到的数据库附加上SQL Server,意味着用户可以直接使用SQL Server管理工具连接数据库,无需额外的设置步骤。 数据库的用户名为"sa",这是SQL Server的默认系统管理员账户,全称为"System Administrator"。...

    sql server 思维导图

    本思维导图旨在概述SQL Server的核心概念、功能和应用场景,帮助初学者和进阶者更好地理解和掌握这一系统。 一、SQL Server基础 SQL Server基于标准的SQL语言,包括SQL查询、插入、更新和删除等基本操作。此外,还...

    SQL Server 2005基础教程

    SQL Server 2005是微软推出的一款强大的关系型数据库管理系统,它在数据存储、处理和分析方面提供了广泛的功能,适用于各种规模的企业。本教程旨在深入浅出地介绍SQL Server 2005的基础知识,帮助初学者快速掌握其...

    toad for sqlserver 6.1免安装

    Toad for SQL Server是一款强大的数据库管理和开发工具,专为SQL Server设计。这款6.1版本的免安装包意味着用户无需经过复杂繁琐的传统安装过程,只需下载单个文件即可开始使用。这种便携式版本尤其适合那些希望在...

    sqlserver2005

    SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在IT领域中扮演着重要的角色,尤其在企业级数据存储、管理和分析方面。本教程将深入探讨SQL Server 2005的主要特性、功能以及实际应用,旨在帮助学习者...

    Sql Server2005数据库

    SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在IT行业中扮演着重要的角色,尤其在数据存储、管理和分析方面。本教程主要关注SQL Server 2005在数据库管理与开发中的应用。 一、SQL Server 2005...

    SQLServer2000

    SQL Server 2000是微软公司推出的一款关系型数据库管理系统,它在IT领域中扮演着重要的角色,尤其是在企业级数据存储和管理方面。这款产品提供了丰富的功能,包括数据存储、查询、分析以及数据安全等,是许多企业和...

    SQL Server 2005开发者指南

    在SQL Server 2005中,开发人员可以利用其高效的T-SQL语言进行复杂的数据操作,构建高效稳定的应用程序。 一、SQL Server 2005核心概念 1. 数据库引擎:这是SQL Server的核心组件,负责数据的存储、处理和安全。它...

    sqlserver2000转2005数据库

    3. **验证数据**:使用SQL Server 2005的兼容性模式在目标服务器上运行SQL Server 2000数据库,检查是否存在问题。 4. **升级数据库**:可以使用“数据库引擎升级顾问”来评估潜在问题,然后通过“数据库导入导出...

    Microsoft SQL Server 保留关键字

    SQL Server 支持 Transact-SQL(T-SQL),这是一种用于管理 SQL Server 数据库的语言。为了确保SQL查询和命令能够被正确解析和执行,SQL Server 定义了一系列保留关键字。这些关键字在SQL语句中有特定的意义,不能...

Global site tag (gtag.js) - Google Analytics