ホームページ  >  記事  >  ウェブフロントエンド  >  jqueryのextendメソッドの解析

jqueryのextendメソッドの解析

一个新手
一个新手オリジナル
2017-10-12 10:26:231492ブラウズ

1. 私は少し前からデータ視覚化 (d3.js、three.js) と PHP の laravel フレームワークの勉強に忙しくしていましたが、これはおそらく人生で多くのことに遭遇しました。

振り返ってみると、私が働き始めた頃、何を学ぶべきかという目標は非常に明確でした。将来どのような高みに到達したいですか?偉大な神々と並んですべてを話し合う必要があります。この目標に向かって努力を続けてください。しかし、いろいろなものを見たり、実行したりするうちに、私はますます混乱してきました。ドゥ・ニアンがいれば、基本的に仕事で問題に遭遇することはないと感じました。

でも、よく考えてみると何も分かりません。目を閉じて書いていると、あれやこれやと思い出せなくなります(年のせいかもしれません)。目標は変わらないのですが、どうすればアイドルになれるのか、迷っています。

一人で目の前の海を漂い、手探りしながら、たくさん回り道をしたはずなのに、前に進み続けていることもわかっています。前進する過程に明るい光が欠けています。どうすれば私たち自身の明るい光を見つけることができるでしょうか。

退屈なとき、私は自分の光を見つけようとjQueryのソースコードを読みました。

/**
    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;
};

この段落はjqueryからのものです。バージョン = バージョン 3.2.1。 視点は人それぞれ違うはずです。間違いがあればご指摘いただければ幸いです。一緒に勉強します。

上記のコードにはまだ理解していない点があります。

 // Prevent never-ending loop 阻止无限循环。 ???没有搞懂,设么情况下才会出现这种情况。 {} != {} 没有想出来什么情况下才会出现target === copy的情况。

                if ( target === copy ) {                    
                continue;
                }

ここまで1/10くらい見て、たくさんのコツを学びました。もしかしたら、本当に自分だけの光を見つけることができるかもしれません。

以上がjqueryのextendメソッドの解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。