资讯专栏INFORMATION COLUMN

基于ES6的tinyJquery

FrozenMap / 1922人阅读

摘要:但它操作的便利性无出其右。我用写了一个基于简化版的,仅做个学习记录。包含基础操作,支持链式操作,仅供日常使用。功能基于基本选择器构造,包括基于原生构造,将原生对象转化为对象。为支持批量操作,构造器应包含复数的。

原文地址:Bougie的博客

jQuery作为曾经Web前端的必备利器,随着MVVM框架的兴起,如今已稍显没落。但它操作DOM的便利性无出其右。我用ES6写了一个基于class简化版的jQuery,仅做个ES6学习记录。包含基础DOM操作,支持链式操作,仅供日常使用。当然,它不支持IE。

内容 构造器(constructor)

构造一个tinyJquery对象。功能:基于基本选择器构造,包括id、class、tagName;基于原生DOM构造,将原生DOM对象转化为tinyJquery对象。为支持批量操作,tinyJquery构造器应包含复数的DOM。

class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 选择器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转tinyJquery
            this.dom = [name]
        }
    }
}

使用$函数构建tinyJquery对象

function $(name) {
    return new tinyJquery(name)
}
方法(后续会渐渐完善) event操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 选择器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转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"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转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"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转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)
        }
    }
}
内容操作
class tinyJquery {
    constructor(name) {
        if (typeof name == "string") {
            // 选择器
            this.dom = document.querySelectorAll(name)
        } else if (name.constructor.name == "NodeList"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转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"){
            // 链式
            this.dom = name
        } else {
            // 原生DOM转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
    }
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/52154.html

相关文章

  • 基于ES6tinyJquery

    摘要:但它操作的便利性无出其右。我用写了一个基于简化版的,仅做个学习记录。包含基础操作,支持链式操作,仅供日常使用。功能基于基本选择器构造,包括基于原生构造,将原生对象转化为对象。为支持批量操作,构造器应包含复数的。 原文地址:Bougie的博客showImg(https://segmentfault.com/img/bV71uK?w=500&h=260);jQuery作为曾经Web前端的必...

    U2FsdGVkX1x 评论0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性无出其右。我用写了一个基于简化版的,包含基础操作,支持链式操作,仅供日常使用。功能基于基本选择器构造,包括基于原生构造,将原生对象转化为对象。为支持批量操作,构造器应包含复数的。 原文地址:Bougie的博客 jQuery作为曾经Web前端的必备利器,随着MVVM框架的兴起,如今已稍显没落。但它操作DOM的便利性无出其右。我用ES6写了一个基于class简化版的jQue...

    happyfish 评论0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性无出其右。我用写了一个基于简化版的,包含基础操作,支持链式操作,仅供日常使用。功能基于基本选择器构造,包括基于原生构造,将原生对象转化为对象。为支持批量操作,构造器应包含复数的。 原文地址:Bougie的博客 jQuery作为曾经Web前端的必备利器,随着MVVM框架的兴起,如今已稍显没落。但它操作DOM的便利性无出其右。我用ES6写了一个基于class简化版的jQue...

    Sleepy 评论0 收藏0
  • 基于ES6tinyJquery

    摘要:但它操作的便利性无出其右。我用写了一个基于简化版的,包含基础操作,支持链式操作,仅供日常使用。功能基于基本选择器构造,包括基于原生构造,将原生对象转化为对象。为支持批量操作,构造器应包含复数的。 原文地址:Bougie的博客 jQuery作为曾经Web前端的必备利器,随着MVVM框架的兴起,如今已稍显没落。但它操作DOM的便利性无出其右。我用ES6写了一个基于class简化版的jQue...

    魏宪会 评论0 收藏0
  • 马上开始写 react & ES6 --- 基于gulp 和 Babel 脚手架

    摘要:我对很有兴趣,但是我发现想写不容易。于是我马上动手,有了这个,本意是自己用,现在也推荐给大家,也希望大家积极指出不足,提出建议,当然如果有更好的方案,也可以推荐给我。特点使用了,这样可以用来书写代码。 我对 react 很有兴趣,但是我发现想写 react 不容易。 我需要在开始写代码之前做很多准备工作,我需要编译jsx文件,引入react等等,而最新的react示例,有鼓励ES6来书...

    Lemon_95 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<