基于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-08JQEasy-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