一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

js提示信息jtip封裝代碼,可以是圖片或文章

話說本人轉行做了前端,于是乎每天都是些div+css啥的。今天就講講這個用js實現類似于A標簽里的title或alt功能,至于這個功能有什么好處呢,你聽我慢慢道來,首先title或alt屬性所帶來的提示太過于簡單,樣式也無法修改,而且鼠標要移到元素上等待1至3秒鐘才會顯示出來,內容也只有簡單的文字,無法加入html內容。所以呢,綜上所述,只好自己封裝一個屬于自己的js提示框了。或許你會說jquery不是有個jtip組件嗎?不錯,那說明你的思想還挺前衛。如果用得習慣的話那就用吧,反正用誰不是用呢?我只是拿出這個小例子來大家研究研究。

首先,我們要做的就是理清思路,做任何事都應該是這樣,不要一拿到東西就開始寫代碼,先要想想我們要得到什么,然后再去付出什么。這就和談戀愛似的,你不能總想著得到對方,而不去想方法去付出,呃,有點扯遠了。我們要得到的是一個全新的提示框,它可以很簡單,也可以很復雜,它應該能包羅萬象海納百川,這就很容易讓人聯想到div。然后我還希望我的鼠標移到某個標簽時他能夠及時的出現在鼠標附近,移開時消失。就這么簡單,現在思路一清晰了,是不是覺得原來就這么容易的一件事。恩,愚子可教也!既然思路也清晰了,那就一步步按照這個思路來實現吧。

先是創建一個DIV出來,并把它隱藏,給它加上你想要的所有樣式。代碼如下:


復制代碼 代碼如下:
var tipdiv = document.createElement("div");
tipdiv.id = "txbtip";
tipdiv.style.position = "absolute";
tipdiv.style.padding = "3px";
tipdiv.style.background = "#565656";
tipdiv.style.zIndex = "999";
tipdiv.style.border = "1px solid #000";
tipdiv.style.background = "#F4F8FC";
tipdiv.style.fontsize = "14px";
var rootEle = document.body || document.documentElement;
rootEle.appendChild(tipdiv);

接著給要添加的標簽加上onmousemove事件和onmouseout事件了,由于為了更公用,所以在這里我給所有要加的標簽一個共同的class名(txbtip)。

復制代碼 代碼如下:
var txbtip = getElementsByClassName('txbtip', 'input');>
function getElementsByClassName(n, tag) {
tag = tag || "*";
var classElements = [], allElements = document.getElementsByTagName(tag);
for (var i = 0; i < allElements.length; i++) {
n = "" + n + "";
var cn = " " + allElements[i].className + " ";
if (cn.indexOf(n) != -1) {
classElements[classElements.length] = allElements[i];
}
}
return classElements;
}

注:這個方法是獲取某些標簽的class為n的集合.
復制代碼 代碼如下:
for (var tip in txbtip) {
var temp = "";
txbtip[tip].onmouseover = function(e) {
tipdiv.style.display = "block";
var title = this.title;
temp = this.title;
this.title = "";//這里這樣做的原因是為了清除原來存在的title提示.
tipdiv.innerHTML = title;
setTipPosition(e);//這個方法是給提示框定位的。
}
txbtip[tip].onmousemove = function(e) {
setTipPosition(e);//這個方法是給提示框定位的。
}
txbtip[tip].onmouseout = function(e) {
//alert("out");
this.title = temp;
temp = "";
tipdiv.style.display = "none";
}



最后就是給標簽定位了,就是上面出現過的setTipPotion方法,它的具體實現如下:
復制代碼 代碼如下:
function setTipPosition(e) {
e = e || event;
tipdiv.style.left = e.clientX + 10 + 'px';
var top = document.body.scrollTop ? document.body.scrollTop : document.documentElement.scrollTop;
tipdiv.style.top = e.clientY + 10 + top + 'px';
}

這樣就算完成得差不多了,然后我們再倒轉過來,把它和頁面綁定相結合起來。于是乎寫進window.onload里吧。

window.onload=function(){...}
然而這樣的話就會有可能出現一個頁面有多個window.onload事件而導至失效,所以還要加些工。而且剛才的提示框的對應標簽也有可能已經有了鼠標事件,也得加個判斷。

if (window.addEventListener) { window.addEventListener("load", ready, false); } else if (window.attachEvent) { window.attachEvent("onload", ready); }
下面是完整的代碼
jstip.js
[code]

//******js文字提示txb20100119********/

if (window.addEventListener) {
window.addEventListener("load", ready, false);
} else if (window.attachEvent) {
window.attachEvent("onload", ready);
}

function ready() {
var txbtip = getElementsByClassName('txbtip', '*');
var tipdiv = document.createElement("div");
tipdiv.id = "txbtip";
tipdiv.style.position = "absolute";
tipdiv.style.padding = "3px";
tipdiv.style.background = "#565656";
tipdiv.style.zIndex = "999";
tipdiv.style.border = "1px solid #000";
tipdiv.style.background = "#F4F8FC";
tipdiv.style.fontsize = "14px";
tipdiv.style.display = "none";
var rootEle = document.body || document.documentElement;
rootEle.appendChild(tipdiv);
for (var tip in txbtip) {
//alert(txbtip[tip].id);
var temp = "";
txbtip[tip].onmouseover = function(e) {
tipdiv.style.display = "block";
var title = this.title;
temp = this.title;
this.title = "";
tipdiv.innerHTML = title;
setTipPosition(e);
//alert(title);
}
txbtip[tip].onmousemove = function(e) {
setTipPosition(e);
}
txbtip[tip].onmouseout = function(e) {
//alert("out");
this.title = temp;
temp = "";
tipdiv.style.display = "none";
}
}


function getElementsByClassName(n, tag) {
tag = tag || "*";
var classElements = [], allElements = document.getElementsByTagName(tag);
for (var i = 0; i < allElements.length; i++) {
n = "" + n + "";
var cn = " " + allElements[i].className + " ";
if (cn.indexOf(n) != -1) {
classElements[classElements.length] = allElements[i];
}
}
return classElements;
}
function setTipPosition(e) {
e = e || event;
tipdiv.style.left = e.clientX + 10 + 'px';
var top = document.body.scrollTop ? document.body.scrollTop : document.documentElement.scrollTop;
tipdiv.style.top = e.clientY + 10 + top + 'px';
}
}
[code]

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]

JavaScript技術js提示信息jtip封裝代碼,可以是圖片或文章,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美性与交视频在线观看 | 视频区 图片区 小说区 | 亚洲韩国日本欧美一区二区三区 | 国产成人亚洲影视在线 | 在线国产一区二区三区 | 国产伦乱| 中国女人一级做受免费视频 | 色女生影院 | 99久久香蕉国产线看观香 | 成年女人免费又黄又爽视频 | 久久国产精品一区二区三区 | 成人在线精品视频 | 色综合五月激情综合色一区 | 国产成人区 | 久久久久久久91精品免费观看 | 1024cc香蕉视频| 色在线视频免费 | 激情文学区 | www.av在线视频 | www色在线| 亚洲热热久久九九精品 | 亚洲十欧美十日韩十国产 | 久青草国产手机视频免费观看 | 国产人成精品综合欧美成人 | 亚洲一区免费观看 | 国产大片好看免费播放 | 成人福利网站在线看视频 | 日韩久久久精品首页 | 日本亚洲精品色婷婷在线影院 | 国产手机国产手机在线 | 成人嗯啊视频在线观看 | 亚洲六月丁香六月婷婷蜜芽 | 精品视频一二三区 | 久久国产亚洲精品麻豆 | 精品在线免费观看视频 | a级国产乱理论片在线观看 a级国产乱理论片在线观看看 | 亚洲香蕉网久久综合影院3p | 日韩激情视频在线观看 | 中国一级特黄真人毛片免费看 | 欧美麻豆久久久久久中文 | 欧美一级做一级做片性十三 |