亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

基于ES6的tinyJquery

U2FsdGVkX1x / 2203人閱讀

摘要:但它操作的便利性無(wú)出其右。我用寫(xiě)了一個(gè)基于簡(jiǎn)化版的,僅做個(gè)學(xué)習(xí)記錄。包含基礎(chǔ)操作,支持鏈?zhǔn)讲僮?,僅供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對(duì)象轉(zhuǎn)化為對(duì)象。為支持批量操作,構(gòu)造器應(yīng)包含復(fù)數(shù)的。

原文地址:Bougie的博客

jQuery作為曾經(jīng)Web前端的必備利器,隨著MVVM框架的興起,如今已稍顯沒(méi)落。但它操作DOM的便利性無(wú)出其右。我用ES6寫(xiě)了一個(gè)基于class簡(jiǎn)化版的jQuery,僅做個(gè)ES6學(xué)習(xí)記錄。包含基礎(chǔ)DOM操作,支持鏈?zhǔn)讲僮?,僅供日常使用。當(dāng)然,它不支持IE。

內(nèi)容 構(gòu)造器(constructor)

構(gòu)造一個(gè)tinyJquery對(duì)象。功能:基于基本選擇器構(gòu)造,包括id、class、tagName;基于原生DOM構(gòu)造,將原生DOM對(duì)象轉(zhuǎn)化為tinyJquery對(duì)象。為支持批量操作,tinyJquery構(gòu)造器應(yīng)包含復(fù)數(shù)的DOM。

class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
}

使用$函數(shù)構(gòu)建tinyJquery對(duì)象

function $(name) {
    return new tinyJquery(name)
}
方法(后續(xù)會(huì)漸漸完善) event操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
    // addEventListener
    on(eventName, fn, bubble = false) {
        this.dom.forEach(i => {
            i.addEventListener(eventName, fn, !bubble)
        })
        return new this.constructor(this.dom)
    }
    // removeEventListener
    un(eventName, fn, bubble = false) {
        this.dom.forEach(i => {
            i.removeEventListener(eventName, fn, !bubble)
        })
        return new this.constructor(this.dom)
    }
}
class操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
    // addClass
    ac(className) {
        this.dom.forEach(i => {
            i.classList.add(className)
        })
        return new this.constructor(this.dom)
    }
    // removeClass
    rc(className) {
        this.dom.forEach(i => {
            i.classList.remove(className)
        })
        return new this.constructor(this.dom)
    }
    // toggleClass
    tc(className) {
        this.dom.forEach(i => {
            i.classList.toggle(className)
        })
        return new this.constructor(this.dom)
    }
    // containClass
    cc(className) {
        let flag = false
        this.dom.forEach(i => {
            if(i.classList.contains(className)) flag = true
        })
        return flag
    }
}
屬性操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
    // set inline style
    css(obj) {
        this.dom.forEach(v => {
            Object.keys(obj).forEach(i => {
                v.style[i] = obj[i]
            })
        })
        return new this.constructor(this.dom)
    }
    // get or set attribute
    attr(key, val) {
        if(key && !val) {
            return this.dom[0].getAttribute(key)
        } else {
            this.dom.forEach(i => {
                i.setAttribute(key, val)
            })
            return new this.constructor(this.dom)
        }
    }
}
內(nèi)容操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
    // get or set input value
    val(val) {
        if(val) {
            this.dom[0].value = val
            return new this.constructor(this.dom)
        } else {
            return this.dom[0].value
        }
    }
    // get or set dom innerHtml
    html(val) {
        if(val) {
            this.dom.forEach(i => {
                i.innerHTML = val
            })
            return new this.constructor(this.dom)
        } else {
            return this.dom[0].innerHTML
        }
    }
}
表單操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 選擇器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 鏈?zhǔn)?            this.dom = name
        } else {
            // 原生DOM轉(zhuǎn)tinyJquery
            this.dom = [name]
        }
    }
    // get JSONData
    serializeObject() {
        let dom = this.dom[0], obj = {}
        dom.querySelectorAll("input, textarea").forEach(i => {
            obj[i.getAttribute("name")] = i.value
        })
        return obj
    }
    // get FormData
    serializeForm() {
        let dom = this.dom[0], form = new FormData()
        dom.querySelectorAll("input, textarea").forEach(i => {
            form.append(i.getAttribute("name"), i.value)
        })
        return form
    }
}

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/115982.html

相關(guān)文章

  • 基于ES6tinyJquery

    摘要:但它操作的便利性無(wú)出其右。我用寫(xiě)了一個(gè)基于簡(jiǎn)化版的,僅做個(gè)學(xué)習(xí)記錄。包含基礎(chǔ)操作,支持鏈?zhǔn)讲僮?,僅供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對(duì)象轉(zhuǎn)化為對(duì)象。為支持批量操作,構(gòu)造器應(yīng)包含復(fù)數(shù)的。 原文地址:Bougie的博客showImg(https://segmentfault.com/img/bV71uK?w=500&h=260);jQuery作為曾經(jīng)Web前端的必...

    FrozenMap 評(píng)論0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性無(wú)出其右。我用寫(xiě)了一個(gè)基于簡(jiǎn)化版的,包含基礎(chǔ)操作,支持鏈?zhǔn)讲僮鳎瑑H供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對(duì)象轉(zhuǎn)化為對(duì)象。為支持批量操作,構(gòu)造器應(yīng)包含復(fù)數(shù)的。 原文地址:Bougie的博客 jQuery作為曾經(jīng)Web前端的必備利器,隨著MVVM框架的興起,如今已稍顯沒(méi)落。但它操作DOM的便利性無(wú)出其右。我用ES6寫(xiě)了一個(gè)基于class簡(jiǎn)化版的jQue...

    happyfish 評(píng)論0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性無(wú)出其右。我用寫(xiě)了一個(gè)基于簡(jiǎn)化版的,包含基礎(chǔ)操作,支持鏈?zhǔn)讲僮鳎瑑H供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對(duì)象轉(zhuǎn)化為對(duì)象。為支持批量操作,構(gòu)造器應(yīng)包含復(fù)數(shù)的。 原文地址:Bougie的博客 jQuery作為曾經(jīng)Web前端的必備利器,隨著MVVM框架的興起,如今已稍顯沒(méi)落。但它操作DOM的便利性無(wú)出其右。我用ES6寫(xiě)了一個(gè)基于class簡(jiǎn)化版的jQue...

    Sleepy 評(píng)論0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性無(wú)出其右。我用寫(xiě)了一個(gè)基于簡(jiǎn)化版的,包含基礎(chǔ)操作,支持鏈?zhǔn)讲僮?,僅供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對(duì)象轉(zhuǎn)化為對(duì)象。為支持批量操作,構(gòu)造器應(yīng)包含復(fù)數(shù)的。 原文地址:Bougie的博客 jQuery作為曾經(jīng)Web前端的必備利器,隨著MVVM框架的興起,如今已稍顯沒(méi)落。但它操作DOM的便利性無(wú)出其右。我用ES6寫(xiě)了一個(gè)基于class簡(jiǎn)化版的jQue...

    魏憲會(huì) 評(píng)論0 收藏0
  • 馬上開(kāi)始寫(xiě) react & ES6 --- 基于gulp 和 Babel 腳手架

    摘要:我對(duì)很有興趣,但是我發(fā)現(xiàn)想寫(xiě)不容易。于是我馬上動(dòng)手,有了這個(gè),本意是自己用,現(xiàn)在也推薦給大家,也希望大家積極指出不足,提出建議,當(dāng)然如果有更好的方案,也可以推薦給我。特點(diǎn)使用了,這樣可以用來(lái)書(shū)寫(xiě)代碼。 我對(duì) react 很有興趣,但是我發(fā)現(xiàn)想寫(xiě) react 不容易。 我需要在開(kāi)始寫(xiě)代碼之前做很多準(zhǔn)備工作,我需要編譯jsx文件,引入react等等,而最新的react示例,有鼓勵(lì)ES6來(lái)書(shū)...

    Lemon_95 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<