茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    jQuery鏈?zhǔn)秸{(diào)用與show知識(shí)淺析
    來源:易賢網(wǎng) 閱讀:982 次 日期:2016-07-01 14:24:23
    溫馨提示:易賢網(wǎng)小編為您整理了“jQuery鏈?zhǔn)秸{(diào)用與show知識(shí)淺析”,方便廣大網(wǎng)友查閱!

    這篇文章主要介紹了jQuery的XX如何實(shí)現(xiàn)?——2.show與鏈?zhǔn)秸{(diào)用 的相關(guān)資料,非常具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧

    jQuery使用許久了,但是有一些API的實(shí)現(xiàn)實(shí)在想不通。下面將使用簡化的代碼來介紹,主要關(guān)注jQuery的實(shí)現(xiàn)思想。

    相較于上一篇,代碼更新了:21~78

    (function(window, undefined){

    function jQuery(sel){

    return new jQuery.prototype.init(sel);

    }

    jQuery.prototype = {

    constructor: jQuery,

    init: function(sel){

    if(typeof sel === 'string'){

    var that = this;

    var nodeList = document.querySelectorAll(sel);

    Array.prototype.forEach.call(nodeList, function(val, i){

    that[i] = val;

    })

    this.selector = sel;

    this.length = nodeList.length;

    }

    },

    show: function(){

    Array.prototype.forEach.call(this, function(node){

    //if(node.style) continue; //textnode沒有style

    //刪除style上的display:none

    var display = node.style.display;

    if(display === 'none'){

    //dispaly置為空后,css如果有display則css的生效

    //否則默認(rèn)的生效

    node.style.display = '';

    }

    //元素display值為非默認(rèn)值情況,需要還原為oldDisplay:div->display:inline-block

    //或 檢測css上的display是否為none

    if(node.style.display==='' || isHidden(node)){

    //有oldDispaly則設(shè)置

    if(node.oldDisplay) node.style.display = node.oldDisplay;

    //沒有則設(shè)置為元素默認(rèn)值或元素當(dāng)前值

    else node.style.display = getDisplay(node);

    }

    })

    //鏈?zhǔn)秸{(diào)用

    return this;

    },

    hide: function(){

    Array.prototype.forEach.call(this, function(node){

    if(!isHidden(node)) {

    //jQuery使用其cache機(jī)制存儲(chǔ)信息,這里簡化一下

    //直接掛載在對應(yīng)的dom下

    node.oldDisplay = getDisplay(node);

    node.style.display = 'none';

    }

    })

    return this;

    }

    }

    function getDisplay(node){

    var display = window.getComputedStyle(node, null).getPropertyValue('display');

    if(display === 'none'){

    var dom = document.createElement(node.nodeName);

    //插入到body中

    document.body.appendChild(dom);

    //即可獲取到元素display的默認(rèn)值

    var display = window.getComputedStyle(dom, null).getPropertyValue('display');

    document.body.removeChild(dom);

    }

    return display;

    }

    function isHidden(node) {

    //忽略未append進(jìn)document的元素這種隱藏情況:$('<div>block</div>')未append

    return window.getComputedStyle(node, null).getPropertyValue('display') === 'none';

    }

    jQuery.prototype.init.prototype = jQuery.prototype;

    window.$ = jQuery;

    })(window);

    先拿hide函數(shù)熱身一下。如上篇提到的,jQuery會(huì)將獲取到的nodeList處理成數(shù)組,所以一上來,我們用forEach處理數(shù)組里的每一個(gè)node節(jié)點(diǎn)。

    接下來,我們只需要將每一個(gè)節(jié)點(diǎn)的style.display置為'none'即可隱藏。很簡單,對吧?(⊙0⊙) 。oldDisplay和return this先不管╰( ̄▽ ̄)╮

    hide: function(){

    Array.prototype.forEach.call(this, function(node){

    if(!isHidden(node)) {

    //jQuery使用其cache機(jī)制存儲(chǔ)信息,這里簡化一下

    //直接掛載在對應(yīng)的dom下

    node.oldDisplay = getDisplay(node);

    node.style.display = 'none';

    }

    })

    return this;

    }

    其中isHidden是判斷該元素是否隱藏:已經(jīng)隱藏的元素就沒必要再去處理了,直接跳過

    function isHidden(node) {

    //忽略未append進(jìn)document的元素這種隱藏情況:$('<div>block</div>')未append

    return window.getComputedStyle(node, null).getPropertyValue('display') === 'none';

    }

    --------------------------

    接下來,來個(gè)稍繁瑣的show。先拋出一個(gè)問題來引發(fā)一系列問題:

    hide某個(gè)元素只需要將display:none,那么show呢?

    display:block不就行了嗎?這樣確實(shí)可以將元素顯示出來。但是萬一元素原來的值是display:inline呢?

    那在hide處保存原來的值不就行了嗎?就像以下的代碼:

    node.oldDisplay = getDisplay(node);

    要是執(zhí)行show前沒有不執(zhí)行hide呢?比如下面這種情況,不就沒有oldDisplay了嗎(⊙0⊙)

    <style>

    div{ display:none; }

    </style>

    <div>display:none</div>$('div').show()

    好,關(guān)鍵的地方到了:我們獲取元素display的默認(rèn)值就可以了吧?比如div默認(rèn)是block,span默認(rèn)是inline。

    思路有了,那么接下來的問題是:如何獲取元素display的默認(rèn)值?

    嘿嘿嘿,想不到吧?這里需要用點(diǎn)小技巧,大體思路如下:通過nodeName創(chuàng)建一個(gè)新的標(biāo)簽,再獲取。

    有個(gè)地方可以再優(yōu)化一下,getDisplay獲取到元素display默認(rèn)值后,可以使用jQuery的cache機(jī)制存起來(實(shí)際上jQuery也是這么做了)。

    function getDisplay(node){

    var display = window.getComputedStyle(node, null).getPropertyValue('display');

    if(display === 'none'){

    var dom = document.createElement(node.nodeName);

    //插入到body中

    document.body.appendChild(dom);

    //即可獲取到元素display的默認(rèn)值

    var display = window.getComputedStyle(dom, null).getPropertyValue('display');

    document.body.removeChild(dom);

    }

    return display;

    }

    然后,綜合這兩種情況:

    //有oldDispaly則設(shè)置

    if(node.oldDisplay) node.style.display = node.oldDisplay;

    //沒有則設(shè)置為元素默認(rèn)值或元素當(dāng)前值

    else node.style.display = getDisplay(node);

    以為這樣就結(jié)束了?NO,show函數(shù)的情況還是挺復(fù)雜的,我們大致要應(yīng)對這幾種情況:

    <style>

    #none,#none2{ display: none; }

    </style>

    <body>

    <div id="div">默認(rèn)值為block</div>

    <span id="span">默認(rèn)值為inline</span>

    <div id="div2" style="display:inline-block;">修改為inline-block</div>

    <div id="none">通過css隱藏了</div>

    <div id="none2" style="display:none">通過css和style隱藏了</div>

    </body>

    最終,show函數(shù)變成了這鬼樣ψ(╰_╯)。大致思路如下:

    名單

    show: function(){

    Array.prototype.forEach.call(this, function(node){

    //if(node.style) continue; //textnode沒有style

    //刪除style上的display:none

    var display = node.style.display;

    if(display === 'none'){

    //dispaly置為空后,css如果有display則css的生效

    //否則默認(rèn)的生效

    node.style.display = '';

    }

    //元素display值為非默認(rèn)值情況,需要還原為oldDisplay:div->display:inline-block

    //或 檢測css上的display是否為none

    if(node.style.display==='' || isHidden(node)){

    //有oldDispaly則設(shè)置

    if(node.oldDisplay) node.style.display = node.oldDisplay;

    //沒有則設(shè)置為元素默認(rèn)值或當(dāng)前值

    else node.style.display = getDisplay(node);

    }

    })

    }

    --------------------------

    鏈?zhǔn)秸{(diào)用就是類似這種情況:

    $('div').show().hide().css('height','300px').toggle()

    實(shí)現(xiàn)起來非常簡單,只要在每個(gè)函數(shù)后面return this即可

    --------------------------

    有同學(xué)說:喂!這個(gè)show,hide不對吧?是不是漏了時(shí)間參數(shù)? 用setTimeOut自己實(shí)現(xiàn)吧~>_<~+。

    本節(jié)最主要是讓大家知道jQuery需要考慮的情況非常多(很多臟活)。即時(shí)簡化了代碼,依然還是這么長。

    寫完后,發(fā)現(xiàn)show還有一種情況沒考慮:

    div{ display:none !important; }

    <div>大家自己開腦洞,怎么處理吧(⊙0⊙)</div>

    更多信息請查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機(jī)網(wǎng)站地址:jQuery鏈?zhǔn)秸{(diào)用與show知識(shí)淺析
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2026上岸·考公考編培訓(xùn)報(bào)班

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)