1. Some time ago, I have been busy studying data visualization (d3.js, three.js) and the laravel framework of PHP. I have also encountered many things in life. This is probably a confused period in life.
Looking back, when I first started working, my goal was very clear, what to learn. What kind of heights do you want to reach in the future? You need to sit side by side with the great gods and talk about everything. We have been
working hard towards this goal. But as I saw and did more things, I became more and more confused - I felt like I knew everything. With Du Niang, I basically wouldn't encounter any problems at work.
But if you think about it carefully, you know nothing. When I write with my eyes closed, I can’t remember this or that (maybe it’s because of my age). The goal has not changed, but how can I become my idol, but I am confused.
Drifting and groping alone in the ocean at the front end, I know that I must have taken many detours, but I also know that I keep moving forward. There is a lack of a bright light in the process of moving forward. How can we find our own bright light?
When I was bored, I read the source code of jQuery, hoping to find my own light.
/** 1. $.extend的用法。 第一个参数是决定是否需要深复制。 由 true, false。 默认是浅复制 params: options => 接收传递过来的arguments 的中间参数。 name => 没对对象的key值。 src => 当传递的对象key值相同到时候。要和并 copy => 复制的value 值。 copyIsArray => 判断value对象是不是数组。 clone => 当深度复制的时候。需要新建一个变量。不会改变原始的值。 target => 最开始是默认值是取传进来的第一个参数。过后往后一直跳。$.extend(a,b,c); target 为 a, 为b,为c。 i => 决定当前target 等于参数中的某个值 length => deep => 默认是false 是决定是否需要深复制的参数。 true 是深复制。 false 是浅复制*/jQuery.extend = jQuery.fn.extend = function() { var options, name, src, copy, copyIsArray, clone, target = arguments[ 0 ] || {}, i = 1, length = arguments.length, deep = false; // 判断 target 来决定是否 深复制 if ( typeof target === "boolean" ) { deep = target; //当深复制的时候,需要跳过第一个参数。 来循环传进来的参数。 刚开始 1,2,3 target = arguments[ i ] || {}; i++; } // 当 target 不是一个对象且 不是一个函数对象 这个时候就把target 变为空对象。 if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { target = {}; } // 如果传递过来的参数只有一个的情况下。target 就是该参数。 if ( i === length ) { target = this; i--; // 把i 改为1 } for ( ; i < length; i++ ) { // 处理非空 或者 undefined 的情况。 null == null 。 undefined == null; //options 是来接收除了第一个参数外的所有参数。中间桥梁的作用吧 if ( ( options = arguments[ i ] ) != null ) { // name in options 决定了 传过来的值必须是对象。如果不是对象的话。将要被拆分 for ( name in options ) { //这个是决定后面同级 的key 值, 后面将要覆盖前面的。 src = target[ name ]; //获取 key值为 name 的 value值。 copy = options[ name ]; // Prevent never-ending loop 阻止无限循环。 ???没有搞懂,设么情况下才会出现这种情况。 if ( target === copy ) { continue; } /** 1.深复制,且value 为对象属性的时候执行递归复制。 isPlainObect(copy) 判断copy第不是一个 纯对象 2.copy 时一个数组的时候。执行里面的函数。 3.(因为只有对象value 和 数组value 是需要进行深复制的。) */ if ( deep && copy && ( jQuery.isPlainObject( copy ) || ( copyIsArray = Array.isArray( copy ) ) ) ) { if ( copyIsArray ) { copyIsArray = false; clone = src && Array.isArray( src ) ? src : []; } else { clone = src && jQuery.isPlainObject( src ) ? src : {}; } // 创建新对象。来进行深度复制。 target[ name ] = jQuery.extend( deep, clone, copy ); //除了对象数组,和undefined 的值。 } else if ( copy !== undefined ) { target[ name ] = copy; } } } } // Return the modified object return target; };
This paragraph comes from jquery. version = version 3.2.1. Everyone's point of view must be different. I hope you can point out any mistakes. study together.
There is something in the above code that I have never figured out.
// Prevent never-ending loop 阻止无限循环。 ???没有搞懂,设么情况下才会出现这种情况。 {} != {} 没有想出来什么情况下才会出现target === copy的情况。 if ( target === copy ) { continue; }
I’ve watched about 1/10 of it so far and learned a lot of tricks. Maybe you can really find your own light.
The above is the detailed content of Analysis of jquery's extend method. For more information, please follow other related articles on the PHP Chinese website!

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version
God-level code editing software (SublimeText3)

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
