基于jQuery實現(xiàn)的QQ表情插件
不廢話了,先給大家展示效果圖:

我們在QQ聊天或者發(fā)表評論、微博時,會有一個允許加入表情的功能,點擊表情按鈕,會彈出一系列表情小圖片,選中某個表情圖片即可發(fā)表的豐富的含表情的內(nèi)容。今天和大家分享一款基于jQuery的QQ表情插件,您可以輕松將其應(yīng)用到你的項目中。
HTML
首先在html頁面的head中引入jQuery庫文件和QQ表情插件jquery.qqFace.js文件。
<script type="text/javascript" src="jquery-1.7.2.min.js"></script> <script type="text/javascript" src="jquery.qqFace.js"></script>
然后在body中加入以下html代碼:
<div id="show"></div> <div class="comment"> <div class="com_form"> <textarea class="input" id="saytext" name="saytext"></textarea> <p><span class="emotion">表情</span><input type="button" class="sub_btn" value="提交"></p> </div> </div>
頁面中有一個輸入框,用來輸入要發(fā)表的內(nèi)容,還有一個表情按鈕,點擊此按鈕可以調(diào)用表情圖片,完了就可以點擊“提交”按鈕發(fā)布帶表情的內(nèi)容了。
CSS
我們用CSS來美化頁面,關(guān)鍵是表情按鈕圖片span.emotion的鼠標(biāo)滑上與移開效果,以及調(diào)用表情插件后,顯示的表情.qqFace面板效果,請看代碼:
.comment{width:680px; margin:20px auto; position:relative}
.comment h3{height:28px; line-height:28px}
.com_form{width:100%; position:relative}
.input{width:99%; height:60px; border:1px solid #ccc}
.com_form p{height:28px; line-height:28px; position:relative}
span.emotion{width:42px; height:20px; background:url(icon.gif) no-repeat 2px 2px;
padding-left:20px; cursor:pointer}
span.emotion:hover{background-position:2px -28px}
.qqFace{margin-top:4px;background:#fff;padding:2px;border:1px #dfe6f6 solid;}
.qqFace table td{padding:0px;}
.qqFace table td img{cursor:pointer;border:1px #fff solid;}
.qqFace table td img:hover{border:1px #0066cc solid;}
#show{width:680px; margin:20px auto}
我們在domo中還用CSS3設(shè)置了提交按鈕的樣式,其代碼在本文中不做解釋,您可以下載代碼了解下。
jQuery
當(dāng)我們點擊頁面輸入框下方那個笑臉時,觸發(fā)調(diào)用qqface表情插件,簡單幾行就搞定。
$(function(){
$('.emotion').qqFace({
assign:'saytext', //給輸入框賦值
path:'face/' //表情圖片存放的路徑
});
...
});
當(dāng)選擇表情圖片后,輸入框中會插入一段如[em_5]之類的代碼,代表插入的表情圖片,實際應(yīng)用中,點提交按鈕后應(yīng)該將這段表情代碼連同其他內(nèi)容插入到數(shù)據(jù)表中。而在頁面顯示的時候,我們應(yīng)該將表情代碼替換成真正的圖片顯示在頁面上。下面的代碼是插入表情圖片后,點擊提交按鈕,使用javascript自定義函數(shù)將表情代碼替換并顯示:
$(function(){
...
$(".sub_btn").click(function(){
var str = $("#saytext").val();
$("#show").html(replace_em(str));
});
});
function replace_em(str){
str = str.replace(/\</g,'<;');
str = str.replace(/\>/g,'>;');
str = str.replace(/\n/g,'<;br/>;');
str = str.replace(/\[em_([0-9]*)\]/g,'<img src="face/$1.gif" border="0" />');
return str;
}
如果您想用PHP代碼來正則替換表情圖片的話,可以使用以下函數(shù):
function ubbReplace($str){
$str = str_replace(">",'<;',$str);
$str = str_replace(">",'>;',$str);
$str = str_replace("\n",'>;br/>;',$str);
$str = preg_replace("[\[em_([0-9]*)\]]",">img src=\"face/$1.gif\" />",$str);
return $str;
}
以上內(nèi)容就是本文對基于jQuery實現(xiàn)的QQ表情插件的詳細(xì)介紹,希望大家喜歡。
- Android輸入框添加emoje表情圖標(biāo)的實現(xiàn)代碼
- Android高仿微信表情輸入與鍵盤輸入詳解
- Android編程開發(fā)之EditText實現(xiàn)輸入QQ表情圖像的方法
- Android編程開發(fā)實現(xiàn)TextView顯示表情圖像和文字的方法
- Android編程實現(xiàn)QQ表情的發(fā)送和接收完整實例(附源碼)
- 基于Android開發(fā)支持表情的實現(xiàn)詳解
- Android開發(fā)技巧之像QQ一樣輸入文字和表情圖像
- 一款支持插入表情的編輯器實現(xiàn)代碼(簡單思路挺重要)
- 使MySQL能夠存儲emoji表情字符的設(shè)置教程
- 完整的Android表情功能處理方案
相關(guān)文章
jQuery CSS3自定義美化Checkbox實現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了jQuery CSS3自定義美化Checkbox實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05
簡單的jquery左側(cè)導(dǎo)航欄和頁面選中效果
這篇文章主要介紹一個簡單的jquery左側(cè)導(dǎo)航欄和頁面選中效果,此功能需引用jquery,需要的朋友可以參考下2014-08-08
JQEasy-ui在IE9以下版本中二次加載的問題分析及處理方法
之前項目中才用了Easy-ui,但是在同時使用tree和grid的效果時,因為頁面有倆個URL,分別為Ajax樹去后臺取數(shù)據(jù)和Grid取數(shù)據(jù),在IE9以上以及其他瀏覽器里都沒有問題,在Ie低版本時會出現(xiàn)先加載表格,然后一閃而過加載樹渲染頁面,造成頁面只有tree數(shù)據(jù)而沒有表格grid數(shù)據(jù)。2014-06-06

