av素人天堂_free性亚洲_久久亚洲国产视频_国产网红在线_午夜av在线播放_欧美成人精品福利网站_热99在线观看_国产在线观看免费麻豆_日本高清在线观看_亚洲免费网站观看视频

JavaScript的深拷貝和淺拷貝

來源:https://segmentfault.com/a/1190000017469386

一直想梳理下工作中經(jīng)常會用到的深拷貝的內(nèi)容,然而遍覽了許多的文章,卻發(fā)現(xiàn)對深拷貝并沒有一個通用的完美實現(xiàn)方式。因為對深拷貝的定義不同,實現(xiàn)時的edge case過多,在深拷貝的時候會出現(xiàn)循環(huán)引用等問題,導(dǎo)致JS內(nèi)部并沒有實現(xiàn)深拷貝,但是我們可以來探究一下深拷貝到底有多復(fù)雜,各種實現(xiàn)方式的優(yōu)缺點,同時參考下常用庫對其的實現(xiàn)。

引用類型

之所以會出現(xiàn)深淺拷貝的問題,實質(zhì)上是由于JS對基本類型和引用類型的處理不同?;绢愋椭傅氖呛唵蔚臄?shù)據(jù)段,而引用類型指的是一個對象,而JS不允許我們直接操作內(nèi)存中的地址,也就是不能操作對象的內(nèi)存空間,所以,我們對對象的操作都只是在操作它的引用而已。

在復(fù)制時也是一樣,如果我們復(fù)制一個基本類型的值時,會創(chuàng)建一個新值,并把它保存在新的變量的位置上。而如果我們復(fù)制一個引用類型時,同樣會把變量中的值復(fù)制一份放到新的變量空間里,但此時復(fù)制的東西并不是對象本身,而是指向該對象的指針。所以我們復(fù)制引用類型后,兩個變量其實指向同一個對象,改變其中一個對象,會影響到另外一個。

var num = 10;
var obj = {
    name: 'Nicholas'
}

var num2 = num;
var obj2 = obj;

obj.name = 'Lee';
obj2.name; // 'Lee'

 

淺拷貝

如果我們要復(fù)制對象的所有屬性都不是引用類型時,就可以使用淺拷貝,實現(xiàn)方式就是遍歷并復(fù)制,最后返回新的對象。

function shallowCopy(obj) {
    var copy = {};
    // 只復(fù)制可遍歷的屬性
    for (key in obj) {
        // 只復(fù)制本身擁有的屬性
        if (obj.hasOwnProperty(key)) {
            copy[key] = obj[key];
        }
    }
    return copy;
}

如上面所說,我們使用淺拷貝會復(fù)制所有引用對象的指針,而不是具體的值,所以使用時一定要明確自己的需求,同時,淺拷貝的實現(xiàn)也是最簡單的。

JS內(nèi)部實現(xiàn)了淺拷貝,如Object.assign(),其中第一個參數(shù)是我們最終復(fù)制的目標(biāo)對象,后面的所有參數(shù)是我們的即將復(fù)制的源對象,支持對象或數(shù)組,一般調(diào)用的方式為

var newObj = Object.assign({}, originObj);

深拷貝

如果我們需要復(fù)制一個擁有所有屬性和方法的新對象,就要用到深拷貝,JS并沒有內(nèi)置深拷貝方法,主要是因為:

  1. 深拷貝怎么定義?我們怎么處理原型?怎么區(qū)分可拷貝的對象?原生DOM/BOM對象怎么拷貝?函數(shù)是新建還是引用?這些edge case太多導(dǎo)致我們無法統(tǒng)一概念,造出大家都滿意的深拷貝方法來。
  2. 內(nèi)部循環(huán)引用怎么處理,是不是保存每個遍歷過的對象列表,每次進(jìn)行對比,然后再造一個循環(huán)引用來?這樣帶來的性能消耗可以接受嗎。

解釋一些常見的問題概念,防止有些同學(xué)不明白我們在講什么。比如循環(huán)引用:

var obj = {};
obj.b = obj;

這樣當(dāng)我們深拷貝obj對象時,就會循環(huán)的遍歷b屬性,直到棧溢出。
我們的解決方案為建立一個集合[],每次遍歷對象進(jìn)行比較,如果[]中已存在,則證明出現(xiàn)了循環(huán)引用或者相同引用,我們直接返回該對象已復(fù)制的引用即可:

let hasObj = [];
function referCopy(obj) {
    let copy = {};
    hasObj.push(obj);
    for (let i in obj) {
        if (typeof obj[i] === 'object') {
            let index = hasObj.indexOf(obj[i]);
            if (index > -1) {
                console.log('存在循環(huán)引用或?qū)傩砸昧讼嗤瑢ο?);
                // 如果已存在,證明引用了相同對象,那么無論是循環(huán)引用還是重復(fù)引用,我們返回引用就可以了
                copy[i] = hasObj[index];
            } else {
                copy[i] = referCopy(obj[i]);
            }
        } else {
            copy[i] = obj[i];
        }
    }
    return copy;
}

處理原型和區(qū)分可拷貝的對象:我們一般使用function.prototype指代原型,使用obj.__proto__指代原型鏈,使用enumerable屬性表示是否可以被for ... in等遍歷,使用hasOwnProperty來查詢是否是本身元素。在原型鏈和可遍歷屬性和自身屬性之間存在交集,但都不相等,我們應(yīng)該如何判斷哪些屬性應(yīng)該被復(fù)制呢?

函數(shù)的處理:函數(shù)擁有一些內(nèi)在屬性,但我們一般不修改這些屬性,所以函數(shù)一般直接引用其地址即可。但是擁有一些存取器屬性的函數(shù)我們怎么處理?是復(fù)制值還是復(fù)制存取描述符?

var obj = {
    age: 10,
    get age() {
        return this.age;
    },
    set age(age) {
        this.age = age;
    }
};
var obj2 = $.extend(true, {}, obj);

obj2; // {age: 10}

這個是我們想要的結(jié)果嗎?大部分場景下不是吧,比如我要復(fù)制一個已有的Vue對象。當(dāng)然我們也有解決方案:

function copy(obj) {
    var copy = {};
    for (var i in obj) {
        let desc = Object.getOwnPropertyDescriptor(obj, i);
        // 檢測是否為存取描述符
        if (desc.set || desc.get) {
            Object.defineProperty(copy, i, {
                get: desc.get,
                set: desc.set,
                configuarable: desc.configuarable,
                enumerable: true
            });
        // 否則為數(shù)據(jù)描述符,則復(fù)用下面的深拷貝方法,此處簡寫
        } else {
            copy[i] = obj[i];
        }
    }
    return copy;
}

雖然邊界條件很多,但是不同的框架和庫都對該方法進(jìn)行了實現(xiàn),只不過定義不同,實現(xiàn)方式也不同,如jQuery.extend()只復(fù)制可枚舉的屬性,不繼承原型鏈,函數(shù)復(fù)制引用,內(nèi)部循環(huán)引用不處理。而lodash實現(xiàn)的就更為優(yōu)秀,它實現(xiàn)了結(jié)構(gòu)化克隆算法。
該算法的優(yōu)點是:

  1. 可以復(fù)制 RegExp 對象。
  2. 可以復(fù)制 Blob、File 以及 FileList 對象。
  3. 可以復(fù)制 ImageData 對象。CanvasPixelArray 的克隆粒度將會跟原始對象相同,并且復(fù)制出來相同的像素數(shù)據(jù)。
  4. 可以正確的復(fù)制有循環(huán)引用的對象

依然存在的缺陷是:

  1. Error 以及 Function 對象是不能被結(jié)構(gòu)化克隆算法復(fù)制的;如果你嘗試這樣子去做,這會導(dǎo)致拋出 DATA_CLONE_ERR 的異常。
  2. 企圖去克隆 DOM 節(jié)點同樣會拋出 DATA_CLONE_ERROR 異常。
  3. 對象的某些特定參數(shù)也不會被保留
    • RegExp 對象的 lastIndex 字段不會被保留
    • 屬性描述符,setters 以及 getters(以及其他類似元數(shù)據(jù)的功能)同樣不會被復(fù)制。例如,如果一個對象用屬性描述符標(biāo)記為 read-only,它將會被復(fù)制為 read-write,因為這是默認(rèn)的情況下。
    • 原形鏈上的屬性也不會被追蹤以及復(fù)制。

我們先來看看常規(guī)的深拷貝,它跟淺拷貝的區(qū)別在于,當(dāng)我們發(fā)現(xiàn)對象的屬性是引用類型時,進(jìn)行遞歸遍歷復(fù)制,直到遍歷完所有屬性:

var deepClone = function(currobj){
    if(typeof currobj !== 'object'){
        return currobj;
    }
    if(currobj instanceof Array){
        var newobj = [];
    }else{
        var newobj = {}
    }
    for(var key in currobj){
        if(typeof currobj[key] !== 'object'){
            // 不是引用類型,則復(fù)制值
            newobj[key] = currobj[key];
        }else{
            // 引用類型,則遞歸遍歷復(fù)制對象
            newobj[key] = deepClone(currobj[key])    
        }
    }
    return newobj
}

這個的主要問題就是不處理循環(huán)引用,不處理對象原型,函數(shù)依然是引用類型。上面描述過的復(fù)雜問題依然存在,可以說是最簡陋但是日常工作夠用的深拷貝方式。

另外還有一種方式是使用JSON序列化,巧妙但是限制更多:

// 調(diào)用JSON內(nèi)置方法先序列化為字符串再解析還原成對象
newObj = JSON.parse(JSON.stringify(obj));

JSON是一種表示結(jié)構(gòu)化數(shù)據(jù)的格式,只支持簡單值、對象和數(shù)組三種類型,不支持變量、函數(shù)或?qū)ο髮嵗?。所以我們工作中可以使用它解決常見問題,但也要注意其短板:函數(shù)會丟失,原型鏈會丟失,以及上面說到的所有缺陷。

庫實現(xiàn)

上面的兩種方式可以滿足大部分場景的需求,如果有更復(fù)雜的需求,可以自己實現(xiàn)?,F(xiàn)在我們可以看一些框架和庫的解決方案,下面拿經(jīng)典的jQuery和lodash的源碼看下,它們的優(yōu)缺點上面都說過了:

jQuery.extend()

// 進(jìn)行深度復(fù)制,如果第一個參數(shù)為true則深度復(fù)制,如果目標(biāo)對象不合法,則拋棄并重構(gòu)為{}空對象,如果只有一個參數(shù)則功能為擴展jQuery對象
jQuery.extend = jQuery.fn.extend = function() {
    var options, name, src, copy, copyIsArray, clone,
        target = arguments[ 0 ] || {},
        i = 1,
        length = arguments.length,
        deep = false;

    // Handle a deep copy situation
    // 第一個參數(shù)可以為true來確定進(jìn)行深度復(fù)制
    if ( typeof target === "boolean" ) {
        deep = target;

        // Skip the boolean and the target
        target = arguments[ i ] || {};
        i++;
    }

    // Handle case when target is a string or something (possible in deep copy)
    // 如果目標(biāo)對象不合法,則強行重構(gòu)為{}空對象,拋棄原有的
    if ( typeof target !== "object" && !jQuery.isFunction( target ) ) {
        target = {};
    }

    // Extend jQuery itself if only one argument is passed
    // 如果只有一個參數(shù),擴展jQuery對象
    if ( i === length ) {
        target = this;
        i--;
    }

    for ( ; i < length; i++ ) {

        // Only deal with non-null/undefined values
        // 只處理有值的對象
        if ( ( options = arguments[ i ] ) != null ) {

            // Extend the base object
            for ( name in options ) {
                src = target[ name ];
                copy = options[ name ];

                // Prevent never-ending loop
                // 阻止最簡單形式的循環(huán)引用
                // var obj={}, obj2={a:obj}; $.extend(true, obj, obj2); 就會形成復(fù)制的對象循環(huán)引用obj
                if ( target === copy ) {
                    continue;
                }
                // 如果為深度復(fù)制,則新建[]和{}空數(shù)組或空對象,遞歸本函數(shù)進(jìn)行復(fù)制
                // Recurse if we're merging plain objects or arrays
                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 : {};
                    }

                    // Never move original objects, clone them
                    target[ name ] = jQuery.extend( deep, clone, copy );

                // Don't bring in undefined values
                } else if ( copy !== undefined ) {
                    target[ name ] = copy;
                }
            }
        }
    }

    // Return the modified object
    return target;
};

lodash _.baseClone()

/**
     * The base implementation of `_.clone` and `_.cloneDeep` which tracks
     * traversed objects.
     *
     * @private
     * @param {*} value The value to clone.
     * @param {boolean} bitmask The bitmask flags.
     *  1 - Deep clone
     *  2 - Flatten inherited properties
     *  4 - Clone symbols
     * @param {Function} [customizer] The function to customize cloning.
     * @param {string} [key] The key of `value`.
     * @param {Object} [object] The parent object of `value`.
     * @param {Object} [stack] Tracks traversed objects and their clone counterparts.
     * @returns {*} Returns the cloned value.
     */
    function baseClone(value, bitmask, customizer, key, object, stack) {
      var result,
          isDeep = bitmask & CLONE_DEEP_FLAG,
          isFlat = bitmask & CLONE_FLAT_FLAG,
          isFull = bitmask & CLONE_SYMBOLS_FLAG;

      if (customizer) {
        result = object ? customizer(value, key, object, stack) : customizer(value);
      }
      if (result !== undefined) {
        return result;
      }
      if (!isObject(value)) {
        return value;
      }
      var isArr = isArray(value);
      if (isArr) {
        result = initCloneArray(value);
        if (!isDeep) {
          return copyArray(value, result);
        }
      } else {
        var tag = getTag(value),
            isFunc = tag == funcTag || tag == genTag;

        if (isBuffer(value)) {
          return cloneBuffer(value, isDeep);
        }
        if (tag == objectTag || tag == argsTag || (isFunc && !object)) {
          result = (isFlat || isFunc) ? {} : initCloneObject(value);
          if (!isDeep) {
            return isFlat
              ? copySymbolsIn(value, baseAssignIn(result, value))
              : copySymbols(value, baseAssign(result, value));
          }
        } else {
          if (!cloneableTags[tag]) {
            return object ? value : {};
          }
          result = initCloneByTag(value, tag, baseClone, isDeep);
        }
      }
      // Check for circular references and return its corresponding clone.
      stack || (stack = new Stack);
      var stacked = stack.get(value);
      if (stacked) {
        return stacked;
      }
      stack.set(value, result);

      var keysFunc = isFull
        ? (isFlat ? getAllKeysIn : getAllKeys)
        : (isFlat ? keysIn : keys);

      var props = isArr ? undefined : keysFunc(value);
      arrayEach(props || value, function(subValue, key) {
        if (props) {
          key = subValue;
          subValue = value[key];
        }
        // Recursively populate clone (susceptible to call stack limits).
        assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));
      });
      return result;
    }

參考資料

  1. 知乎 JS的深拷貝和淺拷貝:?https://www.zhihu.com/questio...
  2. Javascript之深拷貝:?https://aepkill.github.io/201...
  3. js對象克隆之謎:http://b-sirius.me/2017/08/26...
  4. 知乎 JS如何完整實現(xiàn)深度Clone對象:https://www.zhihu.com/questio...
  5. github lodash源碼:https://github.com/lodash/lod...
  6. MDN 結(jié)構(gòu)化克隆算法:https://developer.mozilla.org...
  7. jQuery v3.2.1 源碼
  8. JavaScript高級程序設(shè)計 第4章(變量、作用域和內(nèi)存問題)、第20章(JSON)

 

THE END
av素人天堂_free性亚洲_久久亚洲国产视频_国产网红在线_午夜av在线播放_欧美成人精品福利网站_热99在线观看_国产在线观看免费麻豆_日本高清在线观看_亚洲免费网站观看视频
日本dvd播放| 日本aa大片在线播放免费看| 日本精品在线| 最新国产在线精品91尤物| 极品美乳网红视频免费在线观看| 午夜影院在线免费观看| 日本中文字幕在线看| 人交獸av完整版在线观看| 日本一卡二卡四卡精品| 成年人视频免费看| 天天操天天是| 国产三级视频在线看| 在线观看精品一区二区三区| 国产福利在线播放麻豆| 1pondo在线播放免费| 国产精品人人| 牛牛精品视频在线| 国产欧美黑人| 日本夜夜草视频网站| 伊人av在线com| 豆国产97在线|亚洲| 黄网址在线播放免费| 俄罗斯一级**毛片在线播放| 亚洲精品在线播放视频| 午夜在线小视频| 人人澡人人添人人爽一区二区| 国产无遮挡又黄又爽免费软件| 国产天堂在线观看| 国产一二三视频| 丁香花高清视频完整版在线观看| 最新国产热播激情视频| 中文字幕欧美一区二区| 免费看黄资源大全高清| 精品精品导航| 中文字幕网站视频在线| h网站免费在线观看| 极品白浆推特女神在线观看| 成年女人的天堂在线| 国产丝袜护土调教在线视频| 九九99九九精彩| 亚洲欧美日韩综合精品网| √8天堂资源地址中文在线| 日本免费专区| 免费毛片在线| 丁香花在线电影小说观看| 午夜黄色一级片| 中文字幕在线看精品乱码| 在线看av的网址| 伊人伊人av电影| 激情亚洲综合网| 先锋资源一区二区| 亚洲成人电视网| 精精国产xxxx视频在线| 日本午夜免费福利视频| 天堂中文在线www| 高清美女视频一区| 国产黄色免费网| 五月天丁香在线| 欧美人与牲动交xxxx| 国产最顶级的黄色片在线免费观看| 精品剧情v国产在线观看| 99久久精品国产一区二区小说| 九色视频成人自拍| 日本xxxxxx| 自拍亚洲图区| 国产福利视频在线观看| 久久99精品久久久久久野外| 二区视频在线| 欧洲一区av| 橘梨纱av一区二区三区在线观看| 日本成片免费高清| 国产精选在线观看| 国内精品卡一卡二卡三新区| www亚洲天堂| 香蕉视频在线视频| 免费看黄色的网站| 亚洲美女在线免费观看| aaaaaaa大片免费看| 亚洲高清福利| 九九九九热精品免费视频| 97碰碰碰免费公开在线视频| 看全色黄大色黄大片免责看的| 国产黄色在线观看| mm1313亚洲国产精品美女| 美女91在线| 麻豆视频国产| www在线观看播放免费视频日本| 久本草在线中文字幕亚洲欧美| 精品免费视频一卡2卡三卡4卡不卡| 一个人免费观看视频www在线播放| 在线理论视频| 91视频久色| 男人天堂手机在线| 欧美日韩经典丝袜| 天天射夜夜爽| 午夜av在线免费观看| 久草中文在线| 岛国最新视频免费在线观看| av在线网页| 在线免费看av| 永久免费av片在线观看全网站| 78国产伦精品一区二区三区| 一本加勒比hezyo黑人| 亚洲精品综合一区二区三区| 中文字幕亚洲日本岛国片| 精品剧情v国产在线观看| 久草免费福利视频| 一区二区三区视频在线观看视频| 天天躁日日躁狠狠躁超碰2020| 免费在线毛片网站| x88av蜜桃臀一区二区| 奇米四色7777| 中文字幕在线久热精品| 亚洲第一页在线播放| 2018中文字幕在线观看| 中文字幕高清在线观看| 精品电影在线| 濑亚美莉一二区在线视频| 伊人国产视频| 中文字幕中文字幕在线中高清免费版| 国产黄在线播放| 国产黄色在线| 国产精品久久久精品a级小说| 天天骑天天射| 日本黄色免费在线观看| 牛牛精品在线| 国产精品久久久久一区二区国产| 亚洲精品承认| eeuss在线观看| 成人亚洲欧美日韩在线观看| 亚洲图片欧美| 97最新国自产拍视频在线完整在线看| av免费网站在线| sese一区| 亚洲一道本在线| 在线中文免费视频| 久久久久久久影视| 在线视频1区2区| 国产精品日日爱| fc2人成共享视频在线观看| 国产农村av| 性直播体位视频在线观看| 激情小说 在线视频| 中文字幕在线免费看| 在线看黄网站| 亚洲伊人网在线观看| 亚洲精品在线视频免费| 你懂的视频在线免费| 国产香蕉免费精品视频| 懂色一区二区三区| 青青青国产视频| 国产精彩视频在线观看免费蜜芽| 亚洲无限乱码一二三四麻| 在线黄色国产电影| 九色在线播放| 国产三级在线观看| 日本羞羞视频| 成年网站在线视频网站| 国产女王在线**视频| 狠狠艹夜夜干| 成人黄网18免费观看的网站| 黄色片网站在线| 免费看的av| 午夜激情视频在线| 国产免费福利| 亚洲va在线va天堂成人| 精品视频在线一区二区| 1234区中文字幕在线观看| 国产成人午夜电影| av电影在线观看网址| 在线看黄色av| 欧美人与牲动交xxxx| 国产美女自拍视频| 亚洲第一图区| 国产寡妇树林野战在线播放| 国产系列在线观看| 极品美乳网红视频免费在线观看| 九九99九九精彩| 麻豆福利在线观看| av在线天堂| 亚洲h片在线看| 九九九九热精品免费视频| 成人黄色在线电影| 国产95在线|亚洲| 亚洲成人av在线影院| 久热中文在线| 影音先锋在线中文字幕| 中文产幕区在线观看| 国产又黄又爽又猛免费app| 亚洲在线视频免费| 激情综合丝袜美女一区二区| 北岛玲一区二区三区| 九色porny蝌蚪视频在线观看| 国产永久免费观看| 午夜小视频在线| 成年网站免费入口在线观看| 日本天码aⅴ片在线电影网站| 欧亚成年男女午夜| 极品美女一区二区三区视频| 亚洲精品少妇久久久久久| 青青草在线视频免费观看| 国产一二区视频| 午夜不卡视频| 国产永久免费高清在线观看视频| av高清在线| 国产成人午夜电影| 黄色av观看| 一区三区三区不卡| 夜夜嗨yeyeh| 91九色在线播放| 九色视频网站入口| 轻轻草在线视频| 国产在线拍揄自揄拍视频| 2021av网站| 丁香综合在线| 91国内精品在线视频| 中文字幕视频在线| 作爱视频免费观看视频在线播放激情网| 午夜国产精品理论片久久影院| 九九视频精品在线| 国产精品综合久久久久| 国产精品入口麻豆免费观看| 麻豆蜜桃在线| 久久精品免视着国产成人| 中文字幕色站| 国产一级片麻豆| jizz免费观看视频| 亚洲视频在线网| 国产激情视频一区二区三区| 成视频年人免费看黄网站| 欧美日韩在线中文字幕| 亚洲综合爱爱久久网| 成黄免费在线| www操操操| 久久久久久久久久久久网站| 黄色的网站在线观看| 国产精品入口麻豆完整版| 亚洲综合色视频在线观看| 在线国产福利| 亚洲欧美精品中文第三| 午夜免费视频在线国产| 加勒比一区二区三区在线| 免费av观看网站| 成年人黄色网址| 一二三四区在线观看| 亚洲人成小说| av激情网站| 九色丨porny丨自拍入口| 小早川怜子痴女在线精品视频| 国产超碰在线观看| 99视频免费在线观看| 中文字幕日本在线观看| 日本fc2在线观看| 99色在线视频| 超碰在线免费播放| 天天干天天摸| 青青草原国产在线| 欧美色图自拍| 91亚洲天堂| 精品国产高清自在线一区二区三区| 中文字幕在线影院| 91蜜桃在线视频| 羞羞的网站在线观看| 久草在线国产| 天天综合视频在线观看| 国内视频自拍在线视频| 一本免费视频| 成人免费观看www在线| 国产又猛又黄又爽| 五月天婷亚洲天综合网精品偷| 国产高清av| 国产鲁鲁视频在线观看免费| 欧美性猛交99久久久久99| 99re热久久这里只有精品34| 国产精品剧情一区二区三区| 久久精品最新免费国产成人| 欧美日韩国产亚洲沙发| 97超碰免费在线| 第一中文字幕在线| 天堂资源最新版在线视频观看免费网| 欧美性xxxx交| www.av在线视频| 麻豆av电影在线观看| 免费在线黄色av| 天天综合视频在线观看| av免费在线电影| 免费在线黄网| 中文字幕在线二区| 精品一区二区三区在线成人| 国产乱精品一区二区三区| 18免费在线视频| 日本黄色网网页| 国产精品午夜久久久久久| 97dyy97影院理论片在线| 中文字幕一区二区三区免费视频| 日本小视频在线免费观看| 中文字幕在线一二| 久久久久久久久亚洲精品| 夜夜嗨yeyeh| www.91在线| 青青草在线播放| av福利在线观看| 在线免费观看a视频| 久草免费在线色站| 欧美18一12sex性处hd| 欧美精品久久久久久久久久丰满| а天堂中文在线官网| 全国男人的天堂天堂网| 男女午夜视频在线观看| 国自产拍在线网站网址视频| 天天插天天干| 综合激情丁香| 国产一级黄色电影| 国产精品一区二区婷婷| 18video性欧美19sex高清| 中文字幕在线一二| 免费av在线网址| 国产一级又黄| 天天操天天曰| 日本在线观看| 蜜桃视频在线观看免费视频网站www| 亚洲男人天堂2017| 999久久久免费精品国产牛牛| 浪潮av一区| 成人免费淫片在线费观看| 天天操中文字幕视频| 亚洲啪啪aⅴ一区二区三区9色| 强开小嫩苞一区二区三区视频| 可以在线观看的av| 超碰国产在线| 久操视频在线免费播放| 美女视频一区二区三区在线| 99免费视频| 激情综合丁香| hd国产人妖ts另类视频| 欧美黑人xxxx猛牲大交| 黄色资源在线观看| 亚洲成色在线综合网站2018站| 午夜免费性福利| 天天躁日日躁狠狠躁超碰2020| 亚洲成人在线电影| 成人欧美精品久久久久影院| 天天夜碰日日摸日日澡| 2019年中文字幕| 黄色网址在线免费观看| 免费污视频在线观看| 精品免费视频一卡2卡三卡4卡不卡| 最新中文字幕av专区| 国产又色又爽又黄刺激在线视频| 毛片在线导航| 久热在线视频精品网站| 中文在线二区| 国产午夜三区视频在线| 国产69精品久久app免费版| 男人天堂亚洲天堂| 黄网站在线观看高清免费| 1区2区3区在线视频| 午夜高潮免费视频| www在线视频观看| 国产成人午夜精品| 久热久热免费视频中文字幕777| 黄a免费视频| 免费精品国产自产拍在| 国产免费一级| 久久亚洲国产视频| 久草在线视频网站| 你懂的在线看| 国产欧美日韩专区| 免费看h的网站| 最近中文字幕mv免费高清视频8| 在线欧美一级视频| 青青草视频免费在线观看| 中文xxx视频| 黄色av免费| 国产美女高潮一区二区三区| 国产美女视频一区二区三区| 九色精品高清在线播放| 天天操夜夜欢| 中文字幕在线影院| 9765激情中文在线| 性感av在线播放| 性色视频在线观看| av在线看片| 翔田千里精品久久一区二| 成人video亚洲精品| 日本不卡影院| 亚洲男人天堂2020| 亚洲免费网站观看视频| 日本羞羞视频| 思思99热久久精品在线6| 国产欧美日本亚洲精品一4区| 在线观看免费国产成人软件| 国产一级在线观看www色| 国产精品午夜久久久久久| 特级黄国产片一级视频播放| 欧美性xxxx禁忌| 国产porny蝌蚪视频| 91高清视频在线观看| 成年女人的天堂在线| 夜色福利资源站www国产在线视频|