xhEditor是基于jQuery开发的跨平台轻量可视化XHTML编辑器,基于LGPL开源协议发布。今天就把它山寨一下。

上几张图,看看效果:

先做出菜单部分:发现是一张背景图片,所以用图片映射的方法,可以实现:

img src="xhImages/icon.png" usemap="#iconmap">
map id="iconmap" name="iconmap">
area shape="circle" coords="17,14,12" href="#" title="剪切(Ctrl+X)" id="cut" 
></area>
area shape="circle" coords="40,14,12" href="#" title="复制(Ctrl+C)" id="copy" 
></area>
area shape="circle" coords="63,14,12" href="#" title="粘贴(Ctrl+V)" id="paste"  onmouseover="hiddenDiv();"></area>
area shape="circle" coords="86,14,12" id="special"></area>
div id="specialDiv">
p style="font-size:13px;padding-left:15px;">使用键盘快捷键(Ctrl+V)把内容粘贴到方框里,按 确定</p>
textarea cols="37" rows="5" id="textAreaww"></textarea>
input type="button" onclick="charu('comfirm');" value="确定" 
>
input type="button" onclick="charu('cancel');" value="取消">
div>
  16:  
  17:  
area shape="circle" coords="112,14,12" href="javascript:parag('&lt;p>')" title="段落标签" 
area>
ul id="paraUl">
li><a href="javascript:parag('&lt;p>')"><p>普通段落</p></a></li>
li><a href="javascript:parag('&lt;h1>')"><h1>标题1<h1></a></li>
li><a href="javascript:parag('&lt;h2>')"><h2>标题2</h2></a><li>
li><a href="javascript:parag('&lt;h3>')"><h3>标题3</h3></a></li>
li><a href="javascript:parag('&lt;h4>')"><h4>标题4</h4></a></li>
li><a href="javascript:parag('&lt;h5>')"><h5>标题5</h5></a></li>
li><a href="javascript:parag('&lt;h6>')"><h6>标题6</h6></a></li>
li><a href="javascript:parag('&lt;pre>')"><pre>已编排格式</pre></a></li>
li><a href="javascript:parag('&lt;address>')"><address>地址</addresss></a></li>
ul>

对于其他的area区域用类似的方式,有了静态效果,就可以用js实现简单的交互:隐藏和显示子菜单:

1: var cut = document.getElementById("cut");

   3:     {
   4:         alert("您的浏览器安全设置不允许使用剪切操作,请使用键盘快捷键(Ctrl+X)完成");
   6:     var copy = document.getElementById("copy");
   8:     {
   9:         alert("您的浏览器安全设置不允许使用复制操作,请使用键盘快捷键(Ctrl+C)完成");
  11:     var paste = document.getElementById("paste");
  13:     {
  14:         alert("您的浏览器安全设置不允许使用粘贴操作,请使用键盘快捷键(Ctrl+V)完成");
  16:  
  17:     var special = document.getElementById("special");
  18:     var specialDiv = document.getElementById("specialDiv");
  20:     {
  21:         specialDiv.style.display = "block";
  22:         paraUl.style.display = "none";
  23:         fontUl.style.display = "none";
  24:         sizeUl.style.display="none";
  25:         fontColorDiv.style.display="none";
  26:         bgColorDiv.style.display="none";
  27:         duiqiUl.style.display = "none";
  28:         liebiaoUl.style.display = "none";
  29:         setLDiv.style.display="none";
  30:         tuDiv.style.display="none";
  31:         bqDiv.style.display="none";
  32:         bgDiv.style.display="none";
  33:         codeDiv.style.display="none";
  34:         yyDiv.style.display="none";
  35:     }

对其他的area主要是用mouseover和mouseout事件,然后就是利用execCommand命令将功能应用到

元素。ps:各浏览器对execCommand命令的支持不同,代码在FF和Chrome的新版本中调试过,其他浏览

器未调试,出现不同的结果敬请谅解。

  1. /*
  2. *第二个参数最好不要设置为TRUE,否则可能会执行不了
  3. */
  4. //加粗
  5. function jiacu()
  6. {
  7. document.execCommand("Bold",false,null);
  8. }
  9. //斜体
  10. function xieti()
  11. {
  12. document.execCommand("Italic",false,null);
  13. }
  14. //下划线
  15. function xiahua()
  16. {
  17. document.execCommand("Underline",false,null);
  18. }
  19. //删除线
  20. function shanchu()
  21. {
  22. document.execCommand("StrikeThrough",false,null);
  23. }
  24. //设置字体
  25. function setFontName(param)
  26. {
  27. document.execCommand("FontName",false,param);
  28. document.getElementById("fontUl").style.display="none";
  29. }
  30. //设置字体大小
  31. function setFontSize(param)
  32. {
  33. document.execCommand("FontSize",false,param);
  34. document.getElementById("sizeUl").style.display="none";
  35. }
  36. //设置字体颜色
  37. function setFontColor(param)
  38. {
  39. document.execCommand("ForeColor",false,param)
  40. document.getElementById("fontColor1").style.display="none";
  41. }
  42. //设置背景颜色
  43. function setBackColor(param)
  44. {
  45. document.execCommand("BackColor",false,param)
  46. document.getElementById("bgColor1").style.display="none";
  47. }
  48. //删除文字格式
  49. function removeFormat()
  50. {
  51. document.execCommand("RemoveFormat",false,null);
  52. }
  53. //对齐方式
  54. function duiqiway(param)
  55. {
  56. document.execCommand(param,false,null);
  57. document.getElementById("duiqiUl").style.display="none";
  58. }
  59. //插入列表
  60. function insertList(param)       //不能实现
  61. {
  62. document.execCommand(param,false,null);
  63. alert("暂时未实现");
  64. document.getElementById("liebiaoUl").style.display="none";
  65. }
  66. //改变缩进
  67. function changeIndent(param)    //不能实现
  68. {
  69. document.execCommand(param,false,null);
  70. alert("暂时未实现");
  71. }
  72. //链接                           //不能实现,取消链接的命令只用于用createLink命令创建的链接
  73. function setLink(param)
  74. {
  75. document.execCommand(param,false,"http://blog.csdn.net/u011043843"); //第三个参数为URL
  76. alert("暂时未实现");
  77. }
  78. //表情
  79. function insertBQ(param)
  80. {
  81. document.execCommand("InsertImage",false,param);   //param为图片的url
  82. document.getElementById("bqDiv").style.display="none";
  83. }
  84. //段落
  85. function parag(param)
  86. {
  87. document.execCommand("formatBlock",false,param);
  88. document.getElementById("paraUl").style.display="none";
  89. }

对于execCommand的用法请自行补脑。推荐一个稍官方的链接:https://developer.mozilla.org/zh-CN/docs/Web/API/document.execCommand

由于部分命令浏览器不支持,小编能力也有限,最终只实现了部分功能。不足之处,望读者谅解。

篇幅有限,只写出部分代码。如果你有需要,还请移步下载全部代码:

下载(在底部)

简易博客编辑器:玩转document.execCommand命令的更多相关文章

  1. django 简易博客开发 4 comments库使用及ajax支持

    首先还是贴一下源代码地址  https://github.com/goodspeedcheng/sblog 上一篇文章我们介绍了静态文件使用以及如何使用from实现对blog的增删改,这篇将介绍如何给 ...

  2. Django搭建简易博客

    Django简易博客,主要实现了以下功能 连接数据库 创建超级用户与后台管理 利用django-admin-bootstrap美化界面 template,view与动态URL 多说评论功能 Markd ...

  3. 简易博客[ html + css ] 练习

    1. 前言 通过使用 html + css 编写一个简易的博客作为入门练习 2. 代码及实现 2.1 目录结构 2.2 代码部分 <!DOCTYPE html> <html lang ...

  4. Nodejs+MongoDB+Bootstrap+esj搭建的个人简易博客

    github:https://github.com/yehuimmd/myNodeBloy Nodejs+MongoDB+jQuery+Bootstrap-esj搭建的个人简易博客 主要功能 前台 : ...

  5. 这是通过 Open Live Writer(是个博客编辑器) 发布的

    Open Live Writer  是开源的win10上的博客编辑器

  6. django 简易博客开发 5 markdown支持、代码高亮、gravatar头像服务

    上一篇博客介绍了comments库使用及ajax支持,现在blog已经具备了基本的功能,但是只能发表文字,不支持富文本编辑.今天我们利用markdown添加富文本支持. markdown语法说明: h ...

  7. django 简易博客开发 3 静态文件、from 应用与自定义

    首先还是贴一下源代码地址  https://github.com/goodspeedcheng/sblog 上一篇博客我们介绍了 django 如何在views中使用templates以及一些常用的数 ...

  8. django 简易博客开发 2 模板和数据查询

    首先还是贴一下项目地址  https://github.com/goodspeedcheng/sblog   因为代码全在上面 上一篇博客我们介绍了 django的安装配置,新建project,新建a ...

  9. django 简易博客开发 1 安装、创建、配置、admin使用

    首先贴一下项目地址吧  https://github.com/goodspeedcheng/sblog 到现在位置项目实现的功能有: 1.后台管理使用Admin ,前端显示使用bootstrap 2. ...

随机推荐

  1. html5 Doctor——教你规范使用html5标签

    学习地址(英文资料):http://html5doctor.com/ http://www.w3.org/html/wg/drafts/html/master/text-level-semantics ...

  2. URAL 1012 K-based Numbers. Version 2(DP+高精度)

    题目链接 题意 :与1009一样,不过这个题的数据范围变大. 思路:因为数据范围变大,所以要用大数模拟,用java也行,大数模拟也没什么不过变成二维再做就行了呗.当然也可以先把所有的都进行打表,不过要 ...

  3. Ubuntu环境下手动配置openSSH

    配置openSSH 1.手动下载压缩文件(.tar.gz) zlib-1.2.7.tar.gz openssl-1.0.1j.tar.gz openssh-6.0p1.tar.gz 2.安装zlib ...

  4. HDU4608+模拟

    简单的模拟题. 暴力枚举 /* 模拟 */ #include<algorithm> #include<iostream> #include<string.h> #i ...

  5. 【转】深入研究java.lang.Runtime类

    一.概述      Runtime类封装了运行时的环境.每个 Java 应用程序都有一个 Runtime 类实例,使应用程序能够与其运行的环境相连接.      一般不能实例化一个Runtime对象, ...

  6. linux下添加PATH环境变量

    添加PATH环境变量,第1种方法:[root@lx_web_s1 ~]# export PATH=/usr/local/webserver/mysql/bin:$PATH 再次查看: [root@lx ...

  7. Creating a web server in pure C(c/c++ 写web server)

    一个简单的例子:https://github.com/fekberg/GoHttp 一个运行在windows上例子:http://www.adp-gmbh.ch/win/misc/webserver. ...

  8. 【剑指offer】判断二叉树是否为平衡二叉树

    2013-09-03 14:16:51 面试题39:求二叉树的深度.判断二叉树是否为平衡二叉树 小结: 根据平衡二叉树的定义,需要判断每个结点,因此,需要遍历二叉树的所有结点,并判断以当前结点为根的树 ...

  9. C++ 类的内存分布

    C++类内存分布 转自:http://www.cnblogs.com/jerry19880126/p/3616999.html   先写下总结,通过总结下面的例子,你就会明白总结了. 下面总结一下: ...

  10. git恢复被修改的文件

    恢复到最后一次提交的改动: git checkout -- + 需要恢复的文件名 但是,需要注意的是,如果该文件已经 add 到暂存队列中,上面的命令就不灵光喽 需要先让这个文件取消暂存: git r ...