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

資訊專欄INFORMATION COLUMN

基于ES6的tinyJquery

魏憲會 / 1771人閱讀

摘要:但它操作的便利性無出其右。我用寫了一個基于簡化版的,包含基礎(chǔ)操作,支持鏈式操作,僅供日常使用。功能基于基本選擇器構(gòu)造,包括基于原生構(gòu)造,將原生對象轉(zhuǎn)化為對象。為支持批量操作,構(gòu)造器應(yīng)包含復數(shù)的。

原文地址:Bougie的博客

jQuery作為曾經(jīng)Web前端的必備利器,隨著MVVM框架的興起,如今已稍顯沒落。但它操作DOM的便利性無出其右。我用ES6寫了一個基于class簡化版的jQuery,包含基礎(chǔ)DOM操作,支持鏈式操作,僅供日常使用。當然,它不支持IE。
構(gòu)造器(constructor)

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

class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList" || Array.isArray(name)){
            this.dom = name
        } else {
            this.dom = [name]
        }
    }
}

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

function $(name) {
    return new tinyJquery(name)
}
方法(后續(xù)會漸漸完善) event操作
// addEventListener
on(eventName, fn, bubble = false) {
    this.dom.forEach(i => {
        i.addEventListener(eventName, fn, !bubble)
    })
    return $(this.dom)
}
// removeEventListener
un(eventName, fn, bubble = false) {
    this.dom.forEach(i => {
        i.removeEventListener(eventName, fn, !bubble)
    })
    return $(this.dom)
}
class操作
// addClass
ac(className) {
    this.dom.forEach(i => {
        i.classList.add(className)
    })
    return $(this.dom)
}
// removeClass
rc(className) {
    this.dom.forEach(i => {
        i.classList.remove(className)
    })
    return $(this.dom)
}
// toggleClass
tc(className) {
    this.dom.forEach(i => {
        i.classList.toggle(className)
    })
    return $(this.dom)
}
// containClass
cc(className) {
    let flag = false
    this.dom.forEach(i => {
        if(i.classList.contains(className)) flag = true
    })
    return flag
}
屬性操作
// set inline style
css(obj) {
    this.dom.forEach(v => {
        Object.keys(obj).forEach(i => {
            v.style[i] = obj[i]
        })
    })
    return $(this.dom)
}
// get or set input value
val(val) {
    if(val) {
        this.dom[0].value = val
        return $(this.dom)
    } else {
        return this.dom[0].value
    }
}
內(nèi)容操作
// get or set dom innerHtml
html(val) {
    if(val) {
        this.dom.forEach(i => {
            i.innerHTML = val
        })
        return $(this.dom)
    } else {
        return this.dom[0].innerHTML
    }
}
// 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 $(this.dom)
    }
}
表單操作
// 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
}
2018-04-16更新
Dom獲取
// parent
parent() {
    return $(this.dom[0].parentNode)
}
// siblings
siblings() {
    let dom = this.dom[0]
    var a = [];
    var p = dom.parentNode.children;
    for (var i = 0, pl = p.length; i < pl; i++) {
        if (p[i] !== dom) a.push(p[i]);
    }
    // console.log(Array.isArray(a))
    return $(a)
}
遍歷
// each
each(callback) {
    // this.dom.forEach(i => {
    //     // callback.bind(i)()
    //     callback.call(i, null)
    // })
    this.dom.forEach(i => {
        callback($(i))
    })
}

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

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

相關(guān)文章

  • 基于ES6tinyJquery

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

    U2FsdGVkX1x 評論0 收藏0
  • 基于ES6tinyJquery

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

    FrozenMap 評論0 收藏0
  • 基于ES6tinyJquery

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

    happyfish 評論0 收藏0
  • 基于ES6tinyJquery

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

    Sleepy 評論0 收藏0
  • 馬上開始寫 react & ES6 --- 基于gulp 和 Babel 腳手架

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

    Lemon_95 評論0 收藏0

發(fā)表評論

0條評論

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