jQuery中$()函数的使用方法

本篇文章给大家分享的是关于jquery中$()函数的使用方法,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。

jQuery之$()

一般我们使用jQuery的时候,都是使用$(),$指向全局的jQuery,所以其实是调用了jQuery(),结果是返回一个jq对象,但我们使用时却不需使用new创建对象,所以可以推测$()是一个工厂函数。

$()的定义

jQuery()在src/core.js中定义,若在该方法中调用return new jQuery()则陷入循环,所以调用init()协助构造实例。值得一提的是,jQuery.fn在/src/core.js指向了jQuery.prototype。

    // Define a local copy of jQuery    jQuery = function( selector, context ) {        // The jQuery object is actually just the init constructor 'enhanced'        // Need init if jQuery is called (just allow error to be thrown if not included)        return new jQuery.fn.init( selector, context );    }

登录后复制

init方法的定义

jQuery.fn.init()在src/core/init.js中定义。方法接受三个参数selector, context, root,在方法内部,先判断是否有参数,无参数时返回false。

    init = jQuery.fn.init = function( selector, context, root ) {        var match, elem;        // HANDLE: $(""), $(null), $(undefined), $(false)        if ( !selector ) {            return this;        }        // Method init() accepts an alternate rootjQuery        // so migrate can support jQuery.sub (gh-2101)        root = root || rootjQuery;        // Handle HTML strings        //  或 $(#id)        if ( typeof selector === "string" ) {            if ( selector[ 0 ] === "" &&                selector.length >= 3 ) {                // Assume that strings that start and end with  are HTML and skip the regex check                match = [ null, selector, null ];            } else {                // match[1]是html字符串,match[2]是匹配元素的id                // selector是id选择器时match[1]为undefined,match[2]是匹配元素的id                // selector是html字符串,match[1]是html字符串,match[2]为undefined                match = rquickExpr.exec( selector );            }            // Match html or make sure no context is specified for #id            // 匹配结果非空 且 存在匹配字符串或context空时执行            // 未为id选择器限定查找范围            if ( match && ( match[ 1 ] || !context ) ) {                // HANDLE: $(html) -> $(array)                if ( match[ 1 ] ) {                    context = context instanceof jQuery ? context[ 0 ] : context;                    // Option to run scripts is true for back-compat                    // Intentionally let the error be thrown if parseHTML is not present                    // 生成dom节点并合并到this上                    jQuery.merge( this, jQuery.parseHTML(                        match[ 1 ],                        context && context.nodeType ? context.ownerDocument || context : document,                        true                    ) );                    // HANDLE: $(html, props)                    // 遍历props,添加属性或方法                    if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {                        for ( match in context ) {                            // Properties of context are called as methods if possible                            if ( jQuery.isFunction( this[ match ] ) ) {                                this[ match ]( context[ match ] );                            // ...and otherwise set as attributes                            } else {                                this.attr( match, context[ match ] );                            }                        }                    }                    return this;                // HANDLE: $(#id)                // 处理id选择器且无context                } else {                    elem = document.getElementById( match[ 2 ] );                    if ( elem ) {                        // Inject the element directly into the jQuery object                        this[ 0 ] = elem;                        this.length = 1;                    }                    return this;                }            // HANDLE: $(expr, $(...))            // selector是选择器 context为undefined或context.jquery存在时执行。            // $(#id,context)或$(.class [, context])等情况            } else if ( !context || context.jquery ) {                return ( context || root ).find( selector );            // HANDLE: $(expr, context)            // (which is just equivalent to: $(context).find(expr)            } else {                return this.constructor( context ).find( selector );            }        // HANDLE: $(DOMElement)        // 传入DOM元素        } else if ( selector.nodeType ) {            this[ 0 ] = selector;            this.length = 1;            return this;        // HANDLE: $(function)        // Shortcut for document ready        } else if ( jQuery.isFunction( selector ) ) {            return root.ready !== undefined ?                root.ready( selector ) :                // Execute immediately if ready is not present                selector( jQuery );        }        return jQuery.makeArray( selector, this );    };

登录后复制

selector是字符串

如果有selector非空,先处理selector是字符串的情况,分为html字符串、$(selector)、$(expr, $(…))和$(expr, context)四种。如果selector是字符串类型,根据传入的字符串返回生成的dom节点,处理时先用正则匹配,查找html字符串或id。匹配结果非空且存在匹配字符串或context空时说明selctor是html字符串或selector是id选择器且未限定查找上下文。执行处理html字符串时,先确定生成后的节点要插入的document是哪个(即context参数),默认是加载jQuery的document,调用$.parseHTML()生成dom节点并添加到this;如果context是对象,则是$(html, props)的调用,将属性或者方法挂载到dom上,返回生成的jq对象。如果匹配到$(#id)的调用且context空时,则直接调用document.getElementById查找元素,元素存在时将this[0]指向该元素,返回查找结果。

如果selector不是id选择器或context非空,调用find进行查找,如果context非空,则从context开始查找,否则全局查找,将查找结果作为返回值。

selector是DOM元素

接着处理传入参数是Dom元素的情况。将this[0]指向Dom元素,设置jq对象长度为1,并返回this。

selector是函数

最后处理$(function(){}),如果存在ready则调用传入函数调用ready(f()),否则传入jQuery,直接调用函数,调用makeArray,将其结果作为返回值。

修改init的原型

init = jQuery.fn.init = function( selector, context, root ) {    ...    }// Give the init function the jQuery prototype for later instantiationinit.prototype = jQuery.fn;

登录后复制

在原型上定义方法init,然后将init的原型指向jQuery的原型,如果不这么做,则创建的实例的原型是init.prototype,不是jQuery.fn,其实是init的实例而不是jQuery的实例,无法调用在core.js中定义在jQuery.fn上的各种变量和方法。

相关推荐:

通过Ajax如何请求下载Execl文件

在JS中用slice封装数组方法

以上就是jQuery中$()函数的使用方法的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2745594.html

(0)
上一篇 2025年3月8日 03:46:57
下一篇 2025年2月21日 08:37:44

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js中利用两个栈实现队列的算法

    本篇文章给大家分享的是关于js中利用两个栈实现队列的算法,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 分析 两个栈实现队列,那就…

    编程技术 2025年3月8日
    200
  • js中实现滑动窗口的最大值的算法

    本篇文章给大家分享的是关于js中实现滑动窗口的最大值的算法,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 题目描述 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{2,3,4,2,6,2,5,…

    编程技术 2025年3月8日
    200
  • vue父子组件之间是如何进行传值的

    本篇文章给大家分享的是关于vue父子组件之间是如何进行传值的,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 背景:最近在做vue的项目,因为页面的逻辑比较复杂,代码量较多,所以就想抽离出一些组件放到component里面。问题…

    编程技术 2025年3月8日
    200
  • 如何将JS插件改写成Vue的插件

    本篇文章给大家分享的是关于如何将js插件改写成vue的插件,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 很多刚入坑vue的小伙伴,想用一些原来不用框架的JS插件,用在vue中,可是发现没有效果。这里我先贴个例子。下图是一个插…

    2025年3月8日
    200
  • Koa中发送响应的一种简单的方式

    本篇文章给大家分享的是关于koa中发送响应的一种简单的方式,内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 背景 最近做了很多node的后台项目,写了很多接口,但是发现随着接口的慢慢增多,需要写越来越来越多类似于下面这种代码。 …

    编程技术 2025年3月8日
    200
  • Vue中钩子函数的具体介绍

    这篇文章给大家分享的内容是关于vue的钩子函数[路由导航守卫、keep-alive、生命周期钩子] ,有一定的参考价值,有需要的朋友可以参考一下。 前言 说到Vue的钩子函数,可能很多人只停留在一些很简单常用的钩子(created,moun…

    2025年3月8日
    200
  • 对于JS继承详细介绍( 原型链,构造函数,组合,原型式,寄生式,寄生组合,Class extends)

    这篇文章给大家分享的内容是关于对js继承详细介绍( 原型链,构造函数,组合,原型式,寄生式,寄生组合,class extends),有一定的参考价值,有需要的朋友可以参考一下。 说实在话,以前我只需要知道“寄生组合继承”是最好的,有个祖传代…

    2025年3月8日
    200
  • Vue常用的三种传值方式

    这篇文章给大家分享的内容是关于vue常用的三种传值方式,有一定的参考价值,有需要的朋友可以参考一下。 父组件向子组件进行传值: 父组件: 父组件: import child from ‘./child’ export default { c…

    编程技术 2025年3月8日
    200
  • js中找到两个链表的第一个公共结点的算法

    这篇文章给大家分享的内容是关于js中找到两个链表的第一个公共结点的算法  ,有一定的参考价值,有需要的朋友可以参考一下。 题目描述 输入两个链表,找出它们的第一个公共结点。 分析 考虑到两个链表不一样长的情况,算出两个链表的长度差,然后长的…

    编程技术 2025年3月8日
    200
  • 对React事件系统的解析

    这篇文章给大家分享的内容是关于对react事件系统的解析,有一定的参考价值,有需要的朋友可以参考一下。 一 前言 React事件系统有两类:合成事件和原生事件。在写React组件是我们很容易绑定一个合成事件,但是在一个组件里面是没有办法去绑…

    2025年3月8日
    200

发表回复

登录后才能评论