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 异步调用框架 (Part 1 - 问题 &amp; 场景)
Aug 03 Javascript
jquery lazyload延迟加载技术的实现原理分析
Jan 24 Javascript
基于jquery的使ListNav兼容中文首字拼音排序的实现代码
Jul 10 Javascript
jQuery文本框(input textare)事件绑定方法教程
Apr 24 Javascript
JS文本框追加多个下拉框的值的简单实例
Jul 12 Javascript
在JavaScript中实现类的方式探讨
Aug 28 Javascript
jquery、js调用iframe父窗口与子窗口元素的方法整理
Jul 31 Javascript
JS实现从表格中动态删除指定行的方法
Mar 31 Javascript
jqGrid 学习笔记整理——进阶篇(一 )
Apr 17 Javascript
Bootstrap整体框架之CSS12栅格系统
Dec 15 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
Jun 26 Javascript
anime.js 实现带有描边动画效果的复选框(推荐)
Dec 24 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备份数据库生成SQL文件并下载的函数代码
2012/02/05 PHP
php自定文件保存session的方法
2014/12/10 PHP
laravel实现上传图片,并且制作缩略图,按照日期存放的代码
2019/10/16 PHP
JQuery扩展插件Validate 2通过参数设置验证规则
2011/09/05 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
2013/12/11 Javascript
3种Jquery限制文本框只能输入数字字母的方法
2014/12/03 Javascript
JavaScript面试开发常用的知识点总结
2016/08/08 Javascript
js中获取键盘事件的简单实现方法
2016/10/10 Javascript
js 数据存储和DOM编程
2017/02/09 Javascript
详解Vue 非父子组件通信方法(非Vuex)
2017/05/24 Javascript
SVG动画vivus.js库使用小结(实例代码)
2017/09/14 Javascript
jQuery自动或手动图片切换效果
2017/10/11 jQuery
JavaScript多态与封装实例分析
2018/07/27 Javascript
vue 刷新之后 嵌套路由不变 重新渲染页面的方法
2018/09/13 Javascript
vue悬浮可拖拽悬浮按钮的实例代码
2019/08/20 Javascript
浅谈layui分页控件field参数接收对象的问题
2019/09/20 Javascript
vuejs+element UI table表格中实现禁用部分复选框的方法
2019/09/20 Javascript
使用nodeJS中的fs模块对文件及目录进行读写,删除,追加,等操作详解
2020/02/06 NodeJs
详解javascript void(0)
2020/07/13 Javascript
python编写弹球游戏的实现代码
2018/03/12 Python
详解python深浅拷贝区别
2019/06/24 Python
Python read函数按字节(字符)读取文件的实现
2019/07/03 Python
Python3 执行Linux Bash命令的方法
2019/07/12 Python
浅谈python输出列表元素的所有排列形式
2020/02/26 Python
PyTorch安装与基本使用详解
2020/08/31 Python
python pip如何手动安装二进制包
2020/09/30 Python
说出ArrayList,Vector, LinkedList的存储性能和特性
2015/01/04 面试题
小区停车场管理制度
2014/01/27 职场文书
法人委托书范本格式
2014/09/15 职场文书
悬空寺导游词
2015/02/05 职场文书
幼儿园六一儿童节主持词
2015/06/30 职场文书
2015年食品安全宣传周活动总结
2015/07/09 职场文书
Mac环境Nginx配置和访问本地静态资源的实现
2021/03/31 Servers
详解MySQL多版本并发控制机制(MVCC)源码
2021/06/23 MySQL
JavaScript高级程序设计之变量与作用域
2021/11/17 Javascript
SQL Server Agent 服务无法启动
2022/04/20 SQL Server