首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

jQuery源码浅析

如果说php是世界上最好的语言,那么javascript无疑可以称为世界上最飘逸的语言,最近看了下jQuery源码,实现了一个简陋的jQuery。...DOCTYPE html> jQuery源码浅析 <meta name="...<em>源码</em> * 省略了一些规范,如AMD, Commonjs * 整个<em>jQuery</em>包含在匿名函数中,函数就是闭包 */ (function(window, factory){ factory...的实例,即<em>jQuery</em>对象 * selector待查找的字符串,<em>源码</em>里还有context参数,此处省略 * 我们所说的<em>jQuery</em>其实准确的说是<em>jQuery</em>工厂方法,调用<em>jQuery</em>...= <em>jQuery</em>.fn = <em>jQuery</em>.prototype * <em>jQuery</em>.fn,<em>jQuery</em>.prototype扩展的方法属性 <em>jQuery</em>对象可以使用 */ <em>jQuery</em>.fn.init.prototype

91830
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    jQuery源码解析之position()

    () 作用: 返回被选元素相对于父元素(parent)的偏移坐标 使用: 直接调用$().position()即可,该方法没有 arguments(参数对象) 这是divTwo $("#pTwo").position() //{top: 0, left: 8} 源码...// 返回被选元素相对于父元素(parent)的偏移坐标 // 可以理解成被选元素设置为absolute, // 然后设置left、top的值就是相对于父元素的偏移坐标 // 源码...getBoundingClientRect() 计算的是目标元素的border的位置(左上角),是不包括margin的 ② 如果不加上margin的话(代码是通过减去,来算上margin的),是不准确的,看下图 所以源码最后会...: - jQuery.css( elem, "marginTop", true ) - jQuery.css( elem, "marginLeft", true ) (2)jQuery.css( elem

    61010

    Jquery源码分析-整体结构

    最近在学习Jquery的最新的源码Jquery-3.3.1版本。网上有很多对jquery解析的文章。但是我还是要自己去尝试着看一篇jquery源码。本系列博客用来记录其中的过程,并同大家分享。...本次学习Jquery源码是结合Jquery API来学习的。结合API来学习,首先会让我理解Jquery的整体结构,让我觉得Jquery源码是有迹可循。...如果盲目的去看Jquery源码,10000多行的代码可能会让人望而生畏。   Jquery API 很好地表达了Jquery的整体结构,可以很清楚知道Jquery由哪几部分组成。...Jquery使用   在使用Jquery的时候,可以通过JQuery或者$直接调用Jquery提供的方法,并不需要去实例化Jq对象。...$.extend,是jquery直接提供的静态方法,$()方式调用的是Jquery.fn中的方法。两种不同调用Jquery的方式。

    1.2K20

    jQuery源码解析之$().animate()(上)

    前言: 需要先看 jQuery源码解析之$.queue()、$.dequeue()和jQuery.Callbacks() 一、举例 divA 的宽度先变成 500px,再变成 300px,最后变成 1000px...: //之前有说过: jQuery.fn.extend() 是$()的方法 jQuery.fn.extend( { //源码8062行 //{'width': '500'}...() 作用: 初始化动画对象的属性 源码: //源码8009行 //undefiend undefined undefined //作用是返回一个经过修改的opt对象 jQuery.speed...()),如果是fx动画的话,同时执行出队操作(jQuery.dequeue()) 源码 这个方法上篇文章已经分析过了,这里就简单分析下: jQuery.fn.extend( { //optall.queue...,再运行doAnimation方法; 如果队首元素是inprogress的话,则移除锁 如果队列为空的话,则清空queue,节省内存 源码: //源码4624行 //目标元素,'type'

    74910

    jQuery源码研究:jQuery原型对象上的属性方法(上)

    jQuery源码学习第二节。 今天看下简化框架的第二部分:line: (146 - 225) 为jQ对象添加一些方法和属性。...1jQuery.fn = jQuery.prototype = { 2 constructor: jQuery, 3 length: 0, 4 // 添加原型方法和属性... 5} 从上段代码中可以看到...,jQuery对象作为构造函数,在其原型上定义了一些属性和方法,同时其原型也被指向jQuery对象的属性fn上面。...1//jQuery源码 2var arr = [], 3 slice = arr.slice; 4jQuery.prototype = { 5 toArray: function()...这个方法其实作用就是把元素集合添加到一个新的对象中,并且这个对象还具有jQuery对象的引用,所以也就是具有jQuery对象的所有方法和属性,链式调用起来妥妥的呀。

    1.1K40

    jQuery源码研究:jQuery对象及原型上的extend()方法

    现在看到jQuery的227行,本篇读jQ的继承方法jQuery.extend()。 官方作用解释是将一个或多个对象合并到目标对象中。...看下源码实现: jQuery.extend = jQuery.fn.extend = function(){ //方法体......对象上添加extend属性,并且在jQuery.fn上面也添加同样的extend属性,还记得前面jQuery.fn = jQuery.prototype不?...jQuery对象的fn属性指针就指向jQuery对象的原型,并且因为对象都是引用类型的,所以上例代码的操作意思就是:在jQuery对象和它的原型对象上都添加extend方法,该方法最后返回的是一个合并处理后的对象...jQuery.fn即原型对象上添加extend()方法的代码解释,再复习下:jQuery对象和其原型上都具有extend()方法,区别在于一个是类方法,一个是成员方法,在使用场景上请注意。

    93530

    JS魔法堂:jQuery.Deferred(jQuery1.5-2.1)源码剖析

    一、前言                              jQuery.Deferred作为1.5的新特性出现在jQuery上,而jQuery.ajax函数也做了相应的调整。...而状态间的转换关系如下: initialized -> resolved initialized -> rejected (注意:上述类型和类型状态均根据源码分析得出,源码中并没有明确注明)...jQuery1.5除了新增jQuery.Deferred特性,还以jQuery.Deferred为基础对ajax模块进行增强,相关代码如下: function done( status, statusText...在陷入源码前再次强调一点——1.7与1.6版本在本质上是一点都没变!!  1....Deferred的构建基础,该版本大部分均为对jQuery.Deferred和jQuery.Callbacks代码结构、语义层面的局部重构,使得更容易理解和维护,尤其是对jQuery.Callbacks

    1.9K90
    领券