Hallo.js基于jQuery UI所见即所得的Web编辑器


Posted in Javascript onJanuary 26, 2016

先看看效果:

Hallo.js基于jQuery UI所见即所得的Web编辑器

Hallo.js是一个简单的富文本Web编辑器,基于jQuery UI并且利用HTML5的contentEditable实现所见即所得。其目标并不是取代当今非常流行的编辑器,如 TinyMCE 或 Aloha Editor,而是给开发者提供一种更简单、更愉快的用户编辑体验。

Hallo.js是由Henri Bergius为IKS项目开发的一款免费软件,使用CoffeeScript开发,遵循MIT许可协议,托管在GitHub上。

使用方法

1、你需要将jQuery、jQuery UI和Rangy库引入到你的项目中:

<script src="js/jquery.min.js"></script>
<script src="js/jquery-ui.min.js"></script>
<script src="js/rangy-core.js"></script>

编辑器工具栏使用jQuery UI的主题,因此你可能还想自定义一个主题,适合你的需要。工具栏图标字体基于Font Awesome。风格的工具栏出现在演示中,你也会想添加一些CSS(如背景和边框)的类hallotoolbar。

<link rel="stylesheet" href="/path/to/your/jquery-ui.css">
<link rel="stylesheet" href="/path/to/your/font-awesome.css">

引入Hallo.js

<script src="hallo.js"></script>

调用插件是非常简单的

jQuery('p').hallo();

你也可以关闭标签的编辑功能

jQuery('p').hallo({editable: false});

Hallo自己只能使选择的DOM元素可编辑和不提供任何格式的工具。格式是通过加载插件初始化Hallo。即使简单的事情,如粗体和斜体的插件:

jQuery('.editable').hallo({
 plugins: {
  'halloformat': {}
 }
});

这个例子可以使简单的格式的插件,提供如粗体和斜体的功能。你可以有很多好的插件为你想,如果有必要通过他们的选择。

Hallo有更多的选项设置当实例化。请参阅文档hallo.coffee文件。

事件方法

Hallo有一些事件,有助于整合和调用。你可以使用jQuery bind订阅它们:

  • halloenabled: Triggered when an editable is enabled (editable set to true)
  • hallodisabled: Triggered when an editable is disabled (editable set to false)
  • hallomodified: Triggered whenever user has changed the contents being edited. Event data key content contains the HTML
  • halloactivated: Triggered when user activates an editable area (usually by clicking it)
  • hallodeactivated: Triggered when user deactivates an editable area

插件

  • halloformat ? Adds Bold, Italic, StrikeThrough and Underline support to the toolbar. (Enable/Disable with options: “formattings”: {“bold”: true, “italic”: true, “strikethrough”: true, “underline”: false})
  • halloheadings ? Adds support for H1, H2, H3. You can pass a headings option key to specify what is going to be displayed (e.g. “formatBlocks”:[“p”, “h2″,”h3”])
  • hallojustify ? Adds align left, center, right support
  • hallolists ? Adds support for ordered and unordered lists (Pick with options: “lists”: {“ordered”: false, “unordered”: true})
  • halloreundo ? Adds support for undo and redo
  • hallolink ? Adds support to add links to a selection (currently not working)
  • halloimage ? Image uploading, searching, suggestions
  • halloblacklist ? Filtering unwanted tags from the content

编写一个插件

Hallo插件编写正则jQuery UI插件。

当Hallo加载也加载单元所有启用的插件,并通过他们一些额外的选项:

  • editable: The main Hallo widget instance
  • uuid: unique identifier of the Hallo instance, can be used for element IDs

一个简单的插件看起来像以下的:

#  Formatting plugin for Hallo
#  (c) 2011 Henri Bergius, IKS Consortium
#  Hallo may be freely distributed under the MIT license
((jQuery) ->
 jQuery.widget "IKS.halloformat",
  boldElement: null

  options:
   uuid: ''
   editable: null

  _create: ->
   # Add any actions you want to run on plugin initialization
   # here

  populateToolbar: (toolbar) ->
   # Create an element for holding the button
   @boldElement = jQuery '<span></span>'

   # Use Hallo Button
   @boldElement.hallobutton
    uuid: @options.uuid
    editable: @options.editable
    label: 'Bold'
    # Icons come from Font Awesome
    icon: 'icon-bold'
    # Commands are used for execCommand and queryCommandState
    command: 'bold'

   # Append the button to toolbar
   toolbar.append @boldElement

  cleanupContentClone: (element) ->
   # Perform content clean-ups before HTML is sent out

)(jQuery)

以上就是关于Hallo.js富文本编辑器的详细介绍,希望对大家的学习有所帮助。

Javascript 相关文章推荐
你必须知道的Javascript知识点之&quot;单线程事件驱动&quot;的使用
Apr 23 Javascript
jQuery事件绑定和委托实例
Nov 25 Javascript
全面了解JavaScript对象进阶
Jul 19 Javascript
JavaScript中定义对象原型的两种使用方法
Dec 15 Javascript
JS图片轮播与索引变色功能实例详解
Jul 06 Javascript
JS实现下拉菜单列表与登录注册弹窗效果
Aug 10 Javascript
JS非空验证及邮箱验证的实例
Aug 11 Javascript
浅谈node的事件机制
Oct 09 Javascript
原生js封装添加class,删除class的实例
Nov 06 Javascript
详解用JS添加和删除class类名
Mar 25 Javascript
小程序使用watch监听数据变化的方法详解
Sep 20 Javascript
vue 实现v-for循环回来的数据动态绑定id
Nov 07 Javascript
基于JavaScript如何制作遮罩层对话框
Jan 26 #Javascript
基于Node.js实现nodemailer邮件发送
Jan 26 #Javascript
JavaScript小技巧整理篇(非常全)
Jan 26 #Javascript
基于canvas实现的绚丽圆圈效果完整实例
Jan 26 #Javascript
基于canvas实现的钟摆效果完整实例
Jan 26 #Javascript
js实现的页面矩阵图形变换特效
Jan 26 #Javascript
JS实现简单的二维矩阵乘积运算
Jan 26 #Javascript
You might like
php桌面中心(一) 创建数据库
2007/03/11 PHP
PHP COOKIE设置为浏览器进程
2009/06/21 PHP
PHP时间戳 strtotime()使用方法和技巧
2013/10/29 PHP
php模拟post提交数据的方法
2015/02/12 PHP
Laravel中获取路由参数Route Parameters的五种方法示例
2017/09/29 PHP
php中关于换行的实例写法
2019/09/26 PHP
JavaScript Title、alt提示(Tips)实现源码解读
2010/12/12 Javascript
JavaScript中的console.assert()函数介绍
2014/12/29 Javascript
JavaScript代码实现左右上下自动晃动自动移动
2016/04/08 Javascript
深入理解JavaScript中的for循环
2017/02/07 Javascript
jQuery EasyUI 为Combo,Combobox添加清除值功能的实例
2017/04/13 jQuery
理解javascript async的用法
2017/08/22 Javascript
详解vue指令与$nextTick 操作DOM的不同之处
2018/08/02 Javascript
vue 弹框产生的滚动穿透问题的解决
2018/09/21 Javascript
小程序实现新用户判断并跳转激活的方法
2019/05/20 Javascript
[01:14]英雄,所敬略同——2018完美盛典宣传视频4K
2018/12/05 DOTA
浅析Python中的多进程与多线程的使用
2015/04/07 Python
python函数中return后的语句一定不会执行吗?
2017/07/06 Python
对Python中DataFrame按照行遍历的方法
2018/04/08 Python
利用Python如何实现数据驱动的接口自动化测试
2018/05/11 Python
python实现多人聊天室
2020/03/31 Python
解决pycharm运行时interpreter为空的问题
2018/10/29 Python
Python操作redis实例小结【String、Hash、List、Set等】
2019/05/16 Python
python3.x提取中文的正则表达式示例代码
2019/07/23 Python
关于pytorch处理类别不平衡的问题
2019/12/31 Python
python 爬取B站原视频的实例代码
2020/09/09 Python
几个Linux面试题笔试题
2012/12/01 面试题
历史学专业大学生找工作的自我评价
2013/10/16 职场文书
智能电子应届生求职信
2013/11/10 职场文书
保证书格式范文
2014/04/28 职场文书
保护环境建议书300字
2014/05/13 职场文书
护士医德医风自我评价
2014/09/15 职场文书
2015国庆节66周年演讲稿
2015/03/20 职场文书
调研报告的主要写法
2019/04/18 职场文书
html5表单的required属性使用
2021/07/07 HTML / CSS
Python Pygame实战在打砖块游戏的实现
2022/03/17 Python