JQuery實現(xiàn)超鏈接鼠標(biāo)提示效果的方法
本文實例講述了JQuery實現(xiàn)超鏈接鼠標(biāo)提示效果的方法。分享給大家供大家參考。具體分析如下:
瀏覽器其實已經(jīng)自帶了超鏈接提示,只需在超鏈接中加入title屬性就可以了。但是這個提示效果的響應(yīng)速度是非常緩慢的,大概要延遲1秒左右啊。我們現(xiàn)在需要的是當(dāng)鼠標(biāo)移動到超鏈接的那一瞬間就出現(xiàn)提示。這時就需要移除a標(biāo)簽中的title提示效果,自己動手做一個類似功能的提示。
HTML設(shè)計如下:
然后為class為tooltip的超鏈接添加mouseover和mouseout事件:
$("a.tooltip").mouseover(function (){ //顯示 title }).mouseout(function (){ //隱藏 title });
實現(xiàn)這個效果的具體思路如下:
1. 當(dāng)鼠標(biāo)滑入超鏈接時, 創(chuàng)建一個div元素,div元素的內(nèi)容為title屬性的值。然后將創(chuàng)建的元素追加到文檔中。為它設(shè)置x坐標(biāo)和y坐標(biāo),使它顯示在鼠標(biāo)位置的旁邊。
2. 當(dāng)鼠標(biāo)滑出超鏈接時,移除div元素。
根據(jù)分析的思路,寫出如下JQuery代碼:
$(function(){ var x = 10; var y = 20; $("a.tooltip").mouseover(function(e){ this.myTitle = this.title; this.title = ""; var tooltip = "<div id='tooltip'>"+ this.myTitle +"<\/div>"; //創(chuàng)建 div 元素 $("body").append(tooltip); //把它追加到文檔中 $("#tooltip") .css({ "top": (e.pageY + y) + "px", "left": (e.pageX + x) + "px" }).show("fast"); //設(shè)置x坐標(biāo)和y坐標(biāo),并且顯示 }).mouseout(function(){ this.title = this.myTitle; $("#tooltip").remove(); //移除 }); });
此時的效果有兩個問題:首先是當(dāng)鼠標(biāo)滑過后,a標(biāo)簽中的title屬性的提示也會出現(xiàn):其次是設(shè)置x坐標(biāo)和y坐標(biāo)的問題,由于自制的提示與鼠標(biāo)的距離太近,有時候會引起無法提示的問題(鼠標(biāo)焦點變化引起mouseout事件)。
為了移除a標(biāo)簽中的title提示功能,需要進(jìn)行以下幾個步驟:
1. 當(dāng)鼠標(biāo)滑入時,給對象添加一個新屬性,并把title的值傳給這個屬性,然后清空屬性title的值。
this.myTitle = this.title; s.title = ""; var tooltip = "<div id='tooltip'>"+ this.myTitle +"<\/div>"; //創(chuàng)建 div 元素
2. 當(dāng)鼠標(biāo)滑出時,再把對象的myTitle屬性的值又賦給屬性title。
為什么當(dāng)鼠標(biāo)滑出時,要把屬性值又賦給屬性title呢?因為當(dāng)鼠標(biāo)滑出時,需要考慮再次滑入時的屬性title值,如果不將myTitle的值重新賦給title屬性,當(dāng)再次滑入時,title的值就為空了。
為了解決第2個問題,需要重新設(shè)置提示元素的top和left的值,代碼如下所示,為top增加了10px,為left增加了20px:
var x = lO; var y = 20; $("#tooltip").css({ "top": (e.pageY+y) + "px", "left": (e.pageX+x) + "px" });
OK,到這里問題都解決了,鼠標(biāo)超鏈接提示效果實現(xiàn)。
希望本文所述對大家的jQuery程序設(shè)計有所幫助。
相關(guān)文章
jQuery插件Zclip實現(xiàn)完美兼容個瀏覽器點擊復(fù)制內(nèi)容到剪貼板
本文將結(jié)合實例講解如何使用一款基于jQuery的插件——Zclip來實現(xiàn)復(fù)制內(nèi)容到剪貼板的功能。其實IE上有個方法可以實現(xiàn)點擊復(fù)制,但是由于只是IE獨有,所以我們不提倡。而Zclip是利用一個隱藏的flash文件來完成復(fù)制的功能,關(guān)鍵是它兼容當(dāng)前各主流瀏覽器。2015-04-04基于Jquery的文字滾動跑馬燈插件(一個頁面多個滾動區(qū))
文字逐行或多行滾動跑馬燈插件,基于Jquery。命名為Jquery.RollTitle。支持在一個頁面聲明多個滾動區(qū) (就為了要這點才寫了這個)2010-07-07jquery 得到當(dāng)前頁面高度和寬度的兩個函數(shù)
得到當(dāng)前頁面高度和寬度的兩個函數(shù)2010-02-02AspNet中使用JQuery上傳插件Uploadify詳解
Uploadify是JQuery的一個上傳插件,實現(xiàn)的效果非常不錯,帶進(jìn)度顯示。不過官方提供的實例時php版本的,本文將詳細(xì)介紹Uploadify在Aspnet中的使用2015-05-05jquery.validate[.unobtrusive]和Bootstrap實現(xiàn)tooltip錯誤提示問題分析
這篇文章主要介紹了jquery.validate[.unobtrusive]和Bootstrap實現(xiàn)tooltip錯誤提示問題分析的相關(guān)資料,需要的朋友可以參考下2016-10-10