zoukankan      html  css  js  c++  java
  • 简易博客编辑器:玩转document.execCommand命令

    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的新版本中调试过,其他浏览

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

    [javascript] view plaincopy
    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. //设置字体  
    26. function setFontName(param)  
    27. {  
    28.     document.execCommand("FontName",false,param);  
    29.     document.getElementById("fontUl").style.display="none";   
    30. }  
    31. //设置字体大小  
    32. function setFontSize(param)  
    33. {  
    34.     document.execCommand("FontSize",false,param);  
    35.     document.getElementById("sizeUl").style.display="none";   
    36. }  
    37. //设置字体颜色  
    38. function setFontColor(param)  
    39. {  
    40.     document.execCommand("ForeColor",false,param)  
    41.     document.getElementById("fontColor1").style.display="none";   
    42. }  
    43. //设置背景颜色  
    44. function setBackColor(param)  
    45. {  
    46.     document.execCommand("BackColor",false,param)  
    47.     document.getElementById("bgColor1").style.display="none";   
    48. }  
    49. //删除文字格式  
    50. function removeFormat()  
    51. {  
    52.     document.execCommand("RemoveFormat",false,null);  
    53. }  
    54. //对齐方式  
    55. function duiqiway(param)  
    56. {  
    57.     document.execCommand(param,false,null);  
    58.     document.getElementById("duiqiUl").style.display="none";   
    59. }  
    60. //插入列表  
    61. function insertList(param)       //不能实现  
    62. {  
    63.     document.execCommand(param,false,null);  
    64.     alert("暂时未实现");  
    65.     document.getElementById("liebiaoUl").style.display="none";   
    66. }  
    67. //改变缩进  
    68. function changeIndent(param)    //不能实现  
    69. {  
    70.     document.execCommand(param,false,null);  
    71.     alert("暂时未实现");  
    72. }  
    73. //链接                           //不能实现,取消链接的命令只用于用createLink命令创建的链接  
    74. function setLink(param)  
    75. {  
    76.     document.execCommand(param,false,"http://blog.csdn.net/u011043843"); //第三个参数为URL  
    77.     alert("暂时未实现");  
    78. }  
    79. //表情  
    80. function insertBQ(param)  
    81. {  
    82.     document.execCommand("InsertImage",false,param);   //param为图片的url    
    83.     document.getElementById("bqDiv").style.display="none";   
    84. }  
    85.   
    86. //段落  
    87. function parag(param)  
    88. {  
    89.     document.execCommand("formatBlock",false,param);  
    90.     document.getElementById("paraUl").style.display="none";  
    91. }  

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

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

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

        下载(在底部)


  • 相关阅读:
    Vue多页面 按钮级别权限控制 directive指令控制
    Vue下载页面显示内容
    golang中数组指针和指针数组的区别
    mqtt mosquitto 源码安装
    【后台管理系统】—— Ant Design Pro结合插件(一)
    【后台管理系统】—— Ant Design Pro页面相关(二)
    【后台管理系统】—— Ant Design Pro页面相关(一)
    【后台管理系统】—— Ant Design Pro组件使用(二)
    【后台管理系统】—— Ant Design Pro组件使用(一)
    【千纸诗书】—— PHP/MySQL二手书网站后台开发之知识点记录
  • 原文地址:https://www.cnblogs.com/ido321/p/3947360.html
Copyright © 2011-2022 走看看