成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

一個氣泡提示的Javascript控件

z2xy / 3536人閱讀

摘要:功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。只要在文本框啟用,提交時內(nèi)容為空時就會出現(xiàn)如圖提示。

某日,忽的想寫個js小控件。功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。圖是Chrome里截來的,是Chrome原生的提示樣式。只要在文本框啟用『required』,提交時內(nèi)容為空時就會出現(xiàn)如圖提示。

首先第一步,該是要構(gòu)建一個提示文字的HTML模型,那么彈出提示時就可以被重復(fù)構(gòu)建了(如上圖)。

提示文字..

HTML模型包含兩個部分,提示文字和一個啥也沒有是div,那個div就是用來顯示提示消息上方的小三角的~因此,我們還需要一些CSS來定義賦予樣式。

.megbox{
    position: absolute;
    background-color: #FFF;
    border: 1px solid #a4acb5;
    padding: 5px 10px;
    border-radius: 5px;
    z-index: 100;
}
.megbox_top{
    width: 13px;
    height: 7px;
    position: absolute;
    background: url(./images/up.gif) no-repeat;
    top: -7px;
}
.megbox_meg{
    padding-left: 25px;
    background: url(./images/warning.gif) no-repeat;
    line-height: 20px;
}
.megbox_txt{}/* 暫且保留,說不定以后加點(diǎn)什么樣式~~ */

CSS一共需要調(diào)用到兩張背景圖: 

因?yàn)闅馀萏崾净旧鲜菓腋≡谖谋究蛏戏降?,所以不會被計入正常流中,因此通過「position: absolute」屬性使其脫離正常流。

接下來就是Javascript的部分了。因?yàn)楸救舜髮W(xué)學(xué)的是C++,所以對面向?qū)ο蟊容^鐘情,所以就用面向?qū)Φ姆椒▉黹_發(fā)這個js控件。

首先,定義一下我們需要那些屬性和方法:

屬性:

element:氣泡指向的文本框元素,姑且稱之為目標(biāo)元素吧~;

message:消息提示的內(nèi)容;

id:說不定我們需要彈出好多個提示框,所以我們需要一個唯一標(biāo)識來區(qū)隔它們~;

方法:

Show:顯示氣泡提示;

Remove:移除氣泡;

OK,首先寫個構(gòu)造函數(shù),這個類就叫MessageBox吧~

MessageBox = function(element, id, message)
{
    // Init value
    this.message = "";
    this.element = undefined;   
    this.id = "";

    this.message = message;
    this.element = element;
    this.id = id;
};

接著就是完成兩個方法了~

Show——首先要解決兩個問題:

插入DOM元素;

顯示在哪兒?

第一個問題好解決,查一查W3School就O了~

第二個,因?yàn)槲覀兪怯媒^對定位,而且是要顯示在目標(biāo)元素附近。因此就需要知道目標(biāo)元素的位置。這個嘛…就要Google一下了。

我參照了這位大牛的函數(shù)——阮一峰。

略做修改后,如下:

document.getElementView = function (element)
{
    if(element != document)
        return {
            width: element.offsetWidth,
            height: element.offsetHeight
        }
    if (document.compatMode == "BackCompat"){
        return {
            width: document.body.clientWidth,
            height: document.body.clientHeight
        }
    } else {
        return {
            width: document.documentElement.clientWidth,
            height: document.documentElement.clientHeight
        }
    }
};

document.getElementLeft = function (element)
{
    var actualLeft = element.offsetLeft;
    var current = element.offsetParent;
    while (current !== null){
        actualLeft += current.offsetLeft;
        current = current.offsetParent;
    }
    return actualLeft;
};

document.getElementTop = function (element)
{
    var actualTop = element.offsetTop;
    var current = element.offsetParent;
    while (current !== null){
        actualTop += current.offsetTop;
        current = current.offsetParent;
    }
    return actualTop;
};

把他們都作為document方法加進(jìn)入了~這樣似乎不太好,最安全的做法應(yīng)該是作為MessageBox的私有方法。不過個人喜歡啦~

Remove的話就是把創(chuàng)建的元素刪除而已~

最后方法定義如下:

MessageBox.prototype = {

    constructor : MessageBox, // 聲明構(gòu)造函數(shù)

    Show : function()
    {
        if(!this.element) return false;
        if(this.element.box)
            this.element.box.Remove(true);
        var megbox = document.createElement("div");
        megbox.className = "megbox";
        megbox.id = "megbox_" + this.id;    //把id加上前綴,作為氣泡的id
        var megbox_top = document.createElement("div");
        megbox_top.className = "megbox_top";
        var megbox_meg = document.createElement("div");
        megbox_meg.className = "megbox_meg";
        var megbox_txt = document.createElement("div");
        megbox_txt.className = "megbox_txt";
        var megs=document.createTextNode(this.message);

        megbox.appendChild(megbox_top);
        megbox.appendChild(megbox_meg);
        megbox_meg.appendChild(megbox_txt);
        megbox_txt.appendChild(megs);
        this.element.box = this;

        document.getElementsByTagName("body")[0].appendChild(megbox);

        var node_view = document.getElementView(this.element);
        var node_top = document.getElementTop(this.element);
        var node_left = document.getElementLeft(this.element);

        megbox.style.top = (node_top + node_view.height + 5) + "px";
        megbox.style.left = node_left + "px";

        return true;
    },

    Remove : function()
    {
        var id = this.id;
        var node = document.getElementById("megbox_" + id);
        if(node)
        {
            node.parentNode.removeChild(node);
            return true;
        }
        return false;
    }   
};

因?yàn)樘崾究蝻@示在目標(biāo)元素下方,因此提示框絕對定位的

top = nodetop + nodeview.height + 5 ;(如下圖)

加上5px是為了避免提示框貼在文本框底部。

如此,氣泡提示控件就完成了,調(diào)用時如下:

var test = document.getElementById("test");
var Box = new MessageBox(test, 1, "Test Message.."); 
Box.Show(); // Show the MessageBox

// -----------------------------------

if(Box instanceof MessageBox) Box.Remove(); // Remove MessageBox

最后,附上增強(qiáng)版MessageBox——下載地址??

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/110824.html

相關(guān)文章

  • 一個氣泡提示Javascript控件

    摘要:功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。只要在文本框啟用,提交時內(nèi)容為空時就會出現(xiàn)如圖提示。 showImg(http://segmentfault.com/img/bVbrGa); 某日,忽的想寫個js小控件。功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。圖是Chrome里截來的,是Chrome原生的提示樣式。只要在文本框啟用『required』,提交...

    DataPipeline 評論0 收藏0
  • 一個氣泡提示Javascript控件

    摘要:功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。只要在文本框啟用,提交時內(nèi)容為空時就會出現(xiàn)如圖提示。 showImg(http://segmentfault.com/img/bVbrGa); 某日,忽的想寫個js小控件。功能很簡單,就是可以在文本框下面顯示一個氣泡提示,如上圖。圖是Chrome里截來的,是Chrome原生的提示樣式。只要在文本框啟用『required』,提交...

    VPointer 評論0 收藏0
  • APICloud Github 5大開源項目集合展示

    摘要:自成立之初,一直秉承著開源一切的初心,為了給予廣大開發(fā)者們更多的資源及內(nèi)容。借此,官方將開源項目進(jìn)行分類和介紹,使開發(fā)者們更好的去了解去使用。更多的開源項目均在中。 APICloud自成立之初,一直秉承著開源一切的初心,為了給予廣大開發(fā)者們更多的資源及內(nèi)容。不知不覺,2年時間已過,APICloud的github上已經(jīng)集合了APICloud模塊、前端框架及文檔、云API SDK、開發(fā)工具...

    caspar 評論0 收藏0
  • APICloud Github 5大開源項目集合展示

    摘要:自成立之初,一直秉承著開源一切的初心,為了給予廣大開發(fā)者們更多的資源及內(nèi)容。借此,官方將開源項目進(jìn)行分類和介紹,使開發(fā)者們更好的去了解去使用。更多的開源項目均在中。 APICloud自成立之初,一直秉承著開源一切的初心,為了給予廣大開發(fā)者們更多的資源及內(nèi)容。不知不覺,2年時間已過,APICloud的github上已經(jīng)集合了APICloud模塊、前端框架及文檔、云API SDK、開發(fā)工具...

    EscapedDog 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<