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 相关文章推荐
IE无法设置短域名下Cookie
Sep 23 Javascript
JQuery实现倒计时按钮的实现代码
Mar 23 Javascript
UpdatePanel和Jquery冲突的解决方法
Apr 01 Javascript
javascript实现div的显示和隐藏的小例子
Jun 25 Javascript
与Math.pow 相反的函数使用介绍
Aug 04 Javascript
利用a标签自动解析URL分析网址实例
Oct 20 Javascript
跟我学习javascript的隐式强制转换
Nov 16 Javascript
jquery实现列表上下移动功能
Feb 25 Javascript
jQuery调用Webservice传递json数组的方法
Aug 06 Javascript
EasyUI折叠表格层次显示detailview详解及实例
Dec 28 Javascript
ES6新特性三: Generator(生成器)函数详解
Apr 21 Javascript
JS图片预加载三种实现方法解析
May 08 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读取xml实例代码
2010/01/28 PHP
使用CodeIgniter的类库做图片上传
2014/06/12 PHP
PHP封装的XML简单操作类完整实例
2017/11/13 PHP
js 图片等比例缩放代码
2010/05/13 Javascript
JS实现鼠标单击与双击事件共存
2014/03/08 Javascript
js防止DIV布局滚动时闪动的解决方法
2014/10/30 Javascript
jQuery设置指定网页元素宽度和高度的方法
2015/03/25 Javascript
js实现精美的银灰色竖排折叠菜单
2015/05/16 Javascript
深入浅析Extjs中store分组功能的使用方法
2016/04/20 Javascript
JavaScript Promise 用法
2016/06/14 Javascript
JavaScript鼠标特效大全
2016/09/13 Javascript
原生JS取代一些JQuery方法的简单实现
2016/09/20 Javascript
js仿微信公众平台打标签功能
2017/04/08 Javascript
jQuery插件imgAreaSelect基础讲解
2017/05/26 jQuery
解决js ajax同步请求造成浏览器假死的问题
2018/01/18 Javascript
vue通过路由实现页面刷新的方法
2018/01/25 Javascript
Webpack path与publicPath的区别详解
2018/05/03 Javascript
关于vue3默认把所有onSomething当作v-on事件绑定的思考
2020/05/15 Javascript
vue cli4.0项目引入typescript的方法
2020/07/17 Javascript
[01:54]TI珍贵瞬间系列(五):压力
2020/08/29 DOTA
python使用matplotlib绘制折线图教程
2017/02/08 Python
通过python将大量文件按修改时间分类的方法
2018/10/17 Python
对python 合并 累加两个dict的实例详解
2019/01/21 Python
对Keras中predict()方法和predict_classes()方法的区别说明
2020/06/09 Python
使用CSS3实现SVG路径描边动画效果入门教程
2019/10/21 HTML / CSS
HTML5实现Notification API桌面通知功能
2016/03/02 HTML / CSS
苹果中国官方网站:Apple中国
2016/07/22 全球购物
大学生个人简历自我评价
2013/11/16 职场文书
安全教育心得体会
2013/12/29 职场文书
化工操作工岗位职责
2014/04/29 职场文书
幼儿园安全责任书范本
2014/07/24 职场文书
学校政风行风评议心得体会
2014/10/21 职场文书
农村党建工作汇报材料
2014/10/27 职场文书
红色影片观后感
2015/06/18 职场文书
九年级历史教学反思
2016/02/19 职场文书
Keras在mnist上的CNN实践,并且自定义loss函数曲线图操作
2021/05/25 Python