[力荐]表情选择器

所属分类:输入-丰富的输入

 63372  483  查看评论 (47)
分享到微信朋友圈
X
[力荐]表情选择器 ie兼容6

关于插件

该插件是对 emoji 表情包进行的一个封装,能够很好地运用到我们的项目中去,具有如下特点:

1、可在页面任何地方加入

2、可在单个页面加入多个实例而不会引起冲突

3、可选择获取到插入的表情标识或表情图片路径

4、可定制表情包的分类

5、提供多种参数自定义

使用方法

1、引入 jquery 文件,这里咱们可以直接引用百度的cdn

<script src="http://libs.baidu.com/jquery/1.9.0/jquery.min.js"></script>

2、引入underscore.js 文件,该文件是提供集合的处理

<script type="text/javascript" src="js/underscore-min.js"></script>

3、选择性引入 editor.js 文件。该文件提供了一个文本框插入文本的方法,仅用于需要自己写编辑器插入表情的情况。

<script type="text/javascript" src="js/editor.js"></script>

4、引入改插件的主js文件

<script type="text/javascript" src="js/emojis.js"></script>

5、引入 css 文件,该文件定义了表情选择器的整个样式,当然也可以自己改写其中的某些样式。

<link rel="stylesheet" type="text/css" href="css/emoji.css">

6、指定一个html标签容器供容纳表情

<div id="emoji" class="emoji-container">
    <img  src="emoji/unicode/1f604.png" class="emoji-tbtn">
</div>

该容器包含了一个div和内部的一个img标签。注意:div必须指定ID,默认给了一个  emoji-container 的样式,该样式主要定义了一个 position:relative。保证整个布局不会乱。里面的 img 标签实际上是选择表情的图标,注意里面有个 emoji-tbtn 的class。

7、初始化插件

$('#emoji1').emoji({
  //- 参数列表
});

参数详解

1、data

表情数据,是一个json数组格式如下:

data: [
  {
    "typ":"EmojiCategory-People",
    "nm":"人物",
    "items":[
      {"name":"smile","src":"unicode/1f604.png"},
      {"name":"smiley","src":"unicode/1f603.png"}
    ]
  },
  {
    "typ":"EmojiCategory-Nature",
    "nm":"自然",
    "items":[
      {"name":"smile","src":"unicode/1f604.png"},
      {"name":"smiley","src":"unicode/1f603.png"}
    ]
  },
  .....
]

默认已经有一个表情的数据了,所以一般情况下不需要管这个参数。

2、path

表情图片的路径

3、category

要显示的表情分类。默认的完整分类为:

category: ['EmojiCategory-People','EmojiCategory-Nature','EmojiCategory-Objects','EmojiCategory-Places','EmojiCategory-Symbols']

可以根据自己的需要来增加或删除分类。

4、showbar

是否显示左侧的分类菜单,如果是只显示一个分类,可以选择不显示

5、trigger

分类切换的事件,默认为 "click",即鼠标点左侧的击分类菜单切换标签包,可设置成任何鼠标事件,比如 "mouseover" 即鼠标划过的时候切换。

事件

1、insertAfter

这是该插件唯一的事件,表示点击每个表情图片发生的事件。例如我们要将表情插入到文本框里面去,我们可以这样写。

$(function(){
  var em = $('#emoji').emoji({
     insertAfter: function(item){
        $('#area').insertContent('[:'+item.name+':]')
      }
   });
})

其中 item 参数是一个json对象,包括一个 name 和一个 src。

name 是该表情的字符串标识。

src 表示表情图片的路径。

 数据处理

该表情包是处理前端的展示,最终我们将数据存到了数据库里面,比如一条留言,那么我们该怎么样来展示这条留言呢?有两种方式来阻止文本:

1、直接存表情图片路径

如果我们将表情图片的路径存到了数据库里面,那么直接显示即可,但是这种方式会将图片路径写死,且不易改变数据,很不灵活,所以不推荐使用。

2、存表情的标识,即我们上面提到的 insertAfter 回掉里面的 item.name 。然后我们可以通过正则去将标识替换成图片。

标识的格式可以为

:smile:
[smile]
[:smile:]

也可以定义成我们自己的格式,只要保证插入表情标识的格式和解析的格式一致就OK了。

更新

原插件中的效果是,页面初始化后默认加载第一个分类的所有图片,如果你觉得这会带来额外的带宽,可以选择在点击插入表情图标后才初始化整个插件,而后才加载图片。那么你可以将 emojis.js 中的:

return this.each(function(){
      render_nav(this,options)
      render_emoji(this,options)
      switchitem(this,options)
      togglew(this,options)
    })

修改成

return this.each(function(){
  var obj = this
  $(this).find('.emoji-tbtn').one('click',function(){
        render_nav(obj,options)
        render_emoji(obj,options)
        switchitem(obj,options)
        togglew(obj,options)
   })
})
相关插件-丰富的输入

jQuery表情插件emoji.js

基于jQuery的表情选择,html表情
  丰富的输入
 25192  217

jQuery模拟手机虚拟键盘

虚拟键盘在网络生活中很常见,比如使用网银或在线查询信用卡余额,在输入密码等敏感数据时,应该就会用到虚拟键盘。以防止被恶意程序捕获盗取实际键盘上的操作。
  丰富的输入
 25706  324

仿多说留言、评论框,带微博表情。

仿多说留言、评论框,带微博表情。
  丰富的输入
 58094  626

原生js制作的canvas画板 支持移动版(原创)

原生js制作的画板,刷新更换笔触的颜色,代码注释全,适合学习。
  丰富的输入
 16007  222

讨论这个项目(47)回答他人问题或分享插件使用方法奖励jQ币 评论用户自律公约

    The one 0
    2021/12/29 11:17:23
    你这js都是加密压缩了的,怎么用啊???? 回复
    はつゆきさくら 1
    2019/9/4 19:26:30

    不知道哪个?写的文档 我来说下path 怎么用吧 

     $('#emoji1111').emoji({
         path: '/public/emoji/emoji/'
     });

    首先 这个id不能为emoji1 emoji2 emoji3 会出问题

    回复
    xuanziran 0
    2019/7/19 19:03:01
    请问插入表情图片的时候切换分类会导致自动关闭表情选择框应该怎么修复? 回复
    你先跑,我来抗 0
    2018/10/9 10:06:06
    943006191q,求个emoji插件啊 回复
    邝? 0
    2018/3/2 11:05:50
    感觉代码不全,可扩展性小,使用不方便,自定义的id等等都无法使用
    回复
    hsir 0
    2017/10/17 11:04:54

    如何修改图片路径啊

    我的图片没办法加载,

    请问有解决的办法么

    回复
    一命二运 0
    2017/9/15 13:12:33
    莫伊 0
    2017/8/28 17:18:52

    怎么获得输入的内容啊?能输上去了,提交的时候怎么获得输入的值啊

    回复
    兰阔 0
    2017/6/11 19:09:09
    千万不要下,连个使用方式都没有 回复
    ╃ 伊人未归 ┽ 0
    2017/5/25 14:56:26
    那我想在别的地方打开这个地方的表情呢?还有emoji-container里的input是什么作用也不说明。emoji-tbtn放到别的位置就触发不了,你力荐个卵? 回复
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
取消回复