基于jQuery實(shí)現(xiàn)仿QQ空間送禮物功能代碼
我們?cè)赒Q空間里面有一個(gè)送禮物的功能,顯示了最近過(guò)生日的人。我們只要把鼠標(biāo)放到如下圖的生日快樂(lè)那標(biāo)簽上,就會(huì)顯示可以給該人送的禮物??!
如下圖所示:

單擊其中的一個(gè)禮物,就會(huì)馬上送出去。但是我們現(xiàn)在是要說(shuō)的還有單擊更多的時(shí)候,會(huì)另外彈出一個(gè)新的窗口在當(dāng)前頁(yè)面最前面!如下圖顯示:

怎么實(shí)現(xiàn)那上面的功能呢?
就是把鼠標(biāo)放上去,彈出一天tips,單擊tips里面的控件,之后彈出另外一個(gè)彈出框。
網(wǎng)上就會(huì)有很多比較好的插件,就先到網(wǎng)上去找了相對(duì)應(yīng)的jquery插件。
jquery中tips的有很多插件,但是大部分都是跟隨鼠標(biāo)走的,你離開(kāi)那個(gè)指定的位置就會(huì)消失?,F(xiàn)在這個(gè)是把鼠標(biāo)是要可以放到彈出的tips上面的。之后發(fā)現(xiàn)了一款符合需求又很強(qiáng)大的tips插件poshytip。poshytip使用簡(jiǎn)單,它還可以支持ajax來(lái)動(dòng)態(tài)的加載內(nèi)容來(lái)的,就可以通過(guò)數(shù)據(jù)庫(kù)來(lái)調(diào)用指定分類的禮物出來(lái)了。

更多的poshytip示例和演示在:http://vadikom.com/demos/poshytip/
還需要一個(gè)彈出層的,為了更容易的去實(shí)現(xiàn),把彈出層另外新作了一個(gè)頁(yè)面,點(diǎn)擊更多的時(shí)候在當(dāng)前窗口加載另外一個(gè)新的頁(yè)面作為彈出層。
彈出層的很多,用colorbox等其它jquery插件。直接只用使用之后,發(fā)現(xiàn)彈出來(lái)的窗口說(shuō)鏈接錯(cuò)誤!或者被取消彈出層等。那是因?yàn)槲覀冊(cè)趩螕袅烁嗟臅r(shí)候,彈出了一個(gè)新的窗口,鼠標(biāo)離開(kāi)了tips彈出來(lái)的窗口,這時(shí)候那tips出來(lái)的就會(huì)消失,而彈出加載另外的頁(yè)面的被取消了。
那是要我自己來(lái)弄一個(gè)彈出層插件來(lái)了么,能寫當(dāng)然好 。對(duì)于不是js告訴來(lái),找一款比較簡(jiǎn)單的來(lái)定制不是更快捷。這里http://chabaoo.cn/article/84902.htm比較秀珍的彈出層插件。使用和修改起來(lái)也非常方便了。
用poshytip的方法loadposhytip里面加載了內(nèi)容后就給綁定給更多綁定popdialog方法。只要我們就可以實(shí)現(xiàn)那功能了。
實(shí)現(xiàn)的方式就是那樣的了,下面是我使用的部分js代碼
function loadRecommenClick() {
if ($("#floatBoxBg").length == 0) {
$(".moreRecommend").PopDialog({
Event: "click", //觸發(fā)響應(yīng)事件
title: "送禮物", //彈出層的標(biāo)題
content: "/peoplename/toPeople.aspx?typeId=", //彈出層的內(nèi)容獲取(text文本、容器ID名稱、URL地址、Iframe的地址)
width: 630, //彈出層的寬度
height: 400, //彈出層的高度
scrollTop: 200 //層滑動(dòng)的高度也就是彈出層時(shí)離頂部滑動(dòng)的距離
});
}
}
function loadposhytip(currClass) {
$("." + currClass).poshytip({
className: 'tip-yellowsimple',
content: function (updateCallback) {
classId = $(this).attr("classId");
var htmss = "";
$.getJSON(gifturl + '?ac=1&classId=' + classId + '&pageSize=6&pageIndex=1' + "&r=" + Math.random(),
function (data) {
var container = "<div id=\"sphtml\" class=\"giftInfo1\">";
container += "<div> 精選好禮,點(diǎn)擊就可贈(zèng)送哦!</div>";
container += "<div class=\"birthdayGift\">";
$.each(data[0].items, function (i, item) {
container += " <img src=\"" + item.pic + "\" alt=\"送此件禮物給\" onclick=\"sendgift(this)\" gid=\"" + item.id + "\" yulu=\"" + item.defaultYulu + "\"/>";
});
container += "</div>";
container += "<div class=\"moreRecommend\" >更多推薦</div>";
container += "</div>";
if (data[0].count == "0")
container = "還沒(méi)有添加禮品,請(qǐng)聯(lián)系管理員添加!";
updateCallback(container);
}
);
return "加載中.....";
},
alignTo: 'target',
alignX: 'center',
alignY: 'bottom',
offsetX: 0,
offsetY: 5
});
loadRecommenClick();
}
由于這是用在項(xiàng)目中去了,沒(méi)有做出demo出來(lái),我就只上圖兩種了。其中禮物都是通過(guò)數(shù)據(jù)庫(kù)添加的,ajax加載出來(lái)的。


以上所述是小編給大家介紹的基于jQuery實(shí)現(xiàn)仿QQ空間送禮物功能代碼的相關(guān)知識(shí),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
jQuery實(shí)現(xiàn)簡(jiǎn)易的計(jì)算器
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)簡(jiǎn)易的計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
jQuery插件DataTables分頁(yè)開(kāi)發(fā)心得體會(huì)
這篇文章主要為大家分享了jQuery插件DataTables分頁(yè)開(kāi)發(fā)心得體會(huì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
基于jquery的button默認(rèn)enter事件(回車事件)。
這里我介紹一下,button按鈕默認(rèn)回車(enter)事件。如果大家可以用submit,就不用看以下代碼,因?yàn)閟ubmit可以直接默認(rèn)回車事件(enter)2011-05-05
jQuery easyui的validatebox校驗(yàn)規(guī)則擴(kuò)展及easyui校驗(yàn)框validatebox用法
這篇文章主要介紹了jQuery easyui的validatebox校驗(yàn)規(guī)則擴(kuò)展及easyui校驗(yàn)框validatebox用法的相關(guān)資料,需要的朋友可以參考下2016-01-01
jQuery實(shí)現(xiàn)用方向鍵控制層的上下左右移動(dòng)
本文將會(huì)使用jquery實(shí)現(xiàn)以下功能:按下方向鍵時(shí),使層向相應(yīng)的方向平滑移動(dòng)20像素;四個(gè)方向鍵的鍵碼分別是37(左)、38(上)、39(右)和40(下),感興趣的朋友可以了解下2013-01-01
jquery dialog open后,服務(wù)器端控件失效的快速解決方法
本篇文章是對(duì)jquery dialog open后,服務(wù)器端控件失效的快速解決方法。進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12
ASP.NET jQuery 實(shí)例9 通過(guò)控件hyperlink實(shí)現(xiàn)返回頂部效果
ASP.NET jQuery 實(shí)例9 通過(guò)控件hyperlink實(shí)現(xiàn)返回頂部效果的實(shí)現(xiàn)代碼,需要的朋友可以參考下2012-02-02
Jquery實(shí)現(xiàn)無(wú)縫向上循環(huán)滾動(dòng)列表的特效
今天小編就為大家分享一篇關(guān)于Jquery實(shí)現(xiàn)無(wú)縫向上循環(huán)滾動(dòng)列表的特效,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02
jquery獲取子節(jié)點(diǎn)和父節(jié)點(diǎn)的示例代碼
獲取子節(jié)點(diǎn)和父節(jié)點(diǎn)的方法有很多,在本文為大家詳細(xì)介紹下jquery中時(shí)如何實(shí)現(xiàn)的,感興趣的朋友可以參考下2013-09-09

