美文网首页
走进面向对象编程世界第四步(jquery库)

走进面向对象编程世界第四步(jquery库)

作者: 林立镇 | 来源:发表于2017-08-07 09:53 被阅读0次

为了进一步探索面向对象编程在jquery库的应用
我们需要先了解一下jquery的源码大致情况

自定义jquery库

window.$ = function(selector){
    var array = document.querySelectorAll(selector)
    array.on = function(){}
    array.addClass = function(){}
    array.removeClass =function(){}
    return array
}
function $(selector){
    console.log(this instanceof $)
    var array = document.querySelectorAll(selector)
    for(var i=0;i<array.length;i++){
        this[i] = array[i]
    }
}
console.dir(new $('div'))
true
{0:div,1:div……}
__proto__:Object

将选中的所有div元素返回到数组中

进一步完善jquery()函数

function $(selector){
    if(this instanceof $ === false){
        return new $(selector)
    }else{
        var array = document.querySelectorAll(selector)
        for(var i=0;i<array.length;i++){
        this[i] = array[i]
        }
    }
}
console.dir($('div'))
{0:div,1:div……}
__proto__:Object

如果没有new,则自动通过new实例化构造函数

$.prototype.on = function(){
    console.log('调用了“on”')
    return this
}
$('div').on()

会输出‘调用了“on”’
返回匹配的div元素集合

在引入jquery库的前提下

    <script src="//apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>

增加jquery对象的属性(静态属性)

$.red=function(){
 document.body.style.background = 'red'   
}
$.green=function(){
 document.body.style.background = 'green'   
}
$.red()
$.green()

页面背景变红了

$.redAndGreen = function(){
var color = 'red'
setInterval(function(){
$[color]()
color = color === 'red' ? 'green':'red'
},500)
}
$.redAndGreen()

页面则500毫秒变一次颜色

对jquery的原型进行修改

$.prototype.red = function(){
        for(var i=0;i<this.length;i++){
            this[i].style.background = 'red'
        }
    }
    $('div').red()

$的实例,即所有选中div元素的背景色都会变成红色

    $.prototype.red = function(){
        this.on('click',function(e){
            var $target = $(e.currentTarget)
            $target.css('background','red')
        })
    }
    $('div').red()

匹配div元素在点击后,背景色变成红色

tab组件实战

现在用jquery做一个tab组件
HTML

 <div class=tabs>
        <ol class="tabs-nav">
            <li>nav 1</li>
            <li>nav 2</li>
            <li>nav 3</li>
        </ol>
        <ol class="tabs-content">
            <li>content 1</li>
            <li>content 2</li>
            <li>content 3</li>
        </ol> 
</div>

JS

    $.prototype.tabs = function(){
        this.on('click','.tabs-nav li',function(e){
            var $li = $(e.currentTarget)
            $li.addClass('active').siblings().removeClass('active')
            var index = $li.index()
            var $content = $li.closest('.tabs').find('.tabs-content li').eq(index)
            $content.addClass('active').siblings().removeClass('active')
        })
    }
    $('.tabs').tabs()

CSS

    .active{
        border:1px solid red;
    }
image.png

点击上面的哪行文字,
上面和相面对应位置的文字,
就会加上相应的红色边框

相关文章

  • 走进面向对象编程世界第四步(jquery库)

    为了进一步探索面向对象编程在jquery库的应用我们需要先了解一下jquery的源码大致情况 自定义jquery库...

  • Python学习笔记之类和对象

    面向对象编程,是当前比较主流的编程方式。Python同样支持面向对象编程,在面向对象编程中,可以编写表示现实世界中...

  • 这是我见过最详细的Python面向对象编程!建议收藏!

    面向对象编程和函数式编程(面向过程编程)都是程序设计的方法,不过稍有区别。 面向过程编程: 导入各种外部库 设计各...

  • Swift 面向对象、面向函数、面向协议编程

    一、面向对象编程 OOP(object-oriented programming): 在面向对象编程世界里,一切皆...

  • 13-类

    面向对象 面向对象编程:OOP是利用“类”和“对象”来创建各种模型开实现对现实世界的描述,使用面向对象编程的原因一...

  • Java面向对象学习

    面向对象简介 Java面向对象编程面向对象是一种程序的设计方法,但是并不表示世界上所有的开发者都认同面向对象编程。...

  • 专有名词(持续记录)

    ORM:对象关系映射使用的编程语言是面向对象语言,使用的数据库则是关系型数据库,那么将面向对象的语言和面向关系的数...

  • 面向对象编程

    面向对象编程 面向对象编程 是最有效的软件编写方法之一。在面向对象编程中,你编写表示现实世界中的事物和情景的类,并...

  • Python 面向对象编程

    面向对象编程 面向对象编程 是最有效的软件编写方法之一。在面向对象编程中,你编写表示现实世界中的事物和情景的类,并...

  • 面向对象

    面向对象编程 面向对象编程 是最有效的软件编写方法之一。在面向对象编程中,你编写表示现实世界中的事物和情景的类,并...

网友评论

      本文标题:走进面向对象编程世界第四步(jquery库)

      本文链接:https://www.haomeiwen.com/subject/afxolxtx.html