国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Underscore.js 1.3.3 中文注釋翻譯說明

 更新時(shí)間:2015年06月25日 09:02:27   投稿:junjie  
Underscore一個(gè)JavaScript實(shí)用庫(kù),提供了一整套函數(shù)式編程的實(shí)用功能,但是沒有擴(kuò)展任何JavaScript內(nèi)置對(duì)象,本文就翻譯了它的源代碼中的注釋,需要的朋友可以參考下
// Underscore.js 1.3.3

// (c) 2009-2012 Jeremy Ashkenas, DocumentCloud Inc.

// Underscore is freely distributable under the MIT license.

// Portions of Underscore are inspired or borrowed from Prototype,

// Oliver Steele's Functional, and John Resig's Micro-Templating.

// For all details and documentation:

// http://documentcloud.github.com/underscore

(function() {

 

  // 創(chuàng)建一個(gè)全局對(duì)象, 在瀏覽器中表示為window對(duì)象, 在Node.js中表示global對(duì)象

  var root = this;

 

  // 保存"_"(下劃線變量)被覆蓋之前的值

  // 如果出現(xiàn)命名沖突或考慮到規(guī)范, 可通過_.noConflict()方法恢復(fù)"_"被Underscore占用之前的值, 并返回Underscore對(duì)象以便重新命名

  var previousUnderscore = root._;

 

  // 創(chuàng)建一個(gè)空的對(duì)象常量, 便于內(nèi)部共享使用

  var breaker = {};

 

  // 將內(nèi)置對(duì)象的原型鏈緩存在局部變量, 方便快速調(diào)用

  var ArrayProto = Array.prototype, //

  ObjProto = Object.prototype, //

  FuncProto = Function.prototype;

 

  // 將內(nèi)置對(duì)象原型中的常用方法緩存在局部變量, 方便快速調(diào)用

  var slice = ArrayProto.slice, //

  unshift = ArrayProto.unshift, //

  toString = ObjProto.toString, //

  hasOwnProperty = ObjProto.hasOwnProperty;

 

  // 這里定義了一些JavaScript 1.6提供的新方法

  // 如果宿主環(huán)境中支持這些方法則優(yōu)先調(diào)用, 如果宿主環(huán)境中沒有提供, 則會(huì)由Underscore實(shí)現(xiàn)

  var nativeForEach = ArrayProto.forEach, //

  nativeMap = ArrayProto.map, //

  nativeReduce = ArrayProto.reduce, //

  nativeReduceRight = ArrayProto.reduceRight, //

  nativeFilter = ArrayProto.filter, //

  nativeEvery = ArrayProto.every, //

  nativeSome = ArrayProto.some, //

  nativeIndexOf = ArrayProto.indexOf, //

  nativeLastIndexOf = ArrayProto.lastIndexOf, //

  nativeIsArray = Array.isArray, //

  nativeKeys = Object.keys, //

  nativeBind = FuncProto.bind;

 

  // 創(chuàng)建對(duì)象式的調(diào)用方式, 將返回一個(gè)Underscore包裝器, 包裝器對(duì)象的原型中包含Underscore所有方法(類似與將DOM對(duì)象包裝為一個(gè)jQuery對(duì)象)

  var _ = function(obj) {

    // 所有Underscore對(duì)象在內(nèi)部均通過wrapper對(duì)象進(jìn)行構(gòu)造

    return new wrapper(obj);

  };

  // 針對(duì)不同的宿主環(huán)境, 將Undersocre的命名變量存放到不同的對(duì)象中

  if( typeof exports !== 'undefined') {// Node.js環(huán)境

    if( typeof module !== 'undefined' && module.exports) {

      exports = module.exports = _;

    }

    exports._ = _;

  } else {// 瀏覽器環(huán)境中Underscore的命名變量被掛在window對(duì)象中

    root['_'] = _;

  }

 

  // 版本聲明

  _.VERSION = '1.3.3';

 

  // 集合相關(guān)的方法(數(shù)據(jù)和對(duì)象的通用處理方法)

  // --------------------

 

  // 迭代處理器, 對(duì)集合中每一個(gè)元素執(zhí)行處理器方法

  var each = _.each = _.forEach = function(obj, iterator, context) {

    // 不處理空值

    if(obj == null)

      return;

    if(nativeForEach && obj.forEach === nativeForEach) {

      // 如果宿主環(huán)境支持, 則優(yōu)先調(diào)用JavaScript 1.6提供的forEach方法

      obj.forEach(iterator, context);

    } else if(obj.length === +obj.length) {

      // 對(duì)<數(shù)組>中每一個(gè)元素執(zhí)行處理器方法

      for(var i = 0, l = obj.length; i < l; i++) {

        if( i in obj && iterator.call(context, obj[i], i, obj) === breaker)

          return;

      }

    } else {

      // 對(duì)<對(duì)象>中每一個(gè)元素執(zhí)行處理器方法

      for(var key in obj) {

        if(_.has(obj, key)) {

          if(iterator.call(context, obj[key], key, obj) === breaker)

            return;

        }

      }

    }

  };

  // 迭代處理器, 與each方法的差異在于map會(huì)存儲(chǔ)每次迭代的返回值, 并作為一個(gè)新的數(shù)組返回

  _.map = _.collect = function(obj, iterator, context) {

    // 用于存放返回值的數(shù)組

    var results = [];

    if(obj == null)

      return results;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的map方法

    if(nativeMap && obj.map === nativeMap)

      return obj.map(iterator, context);

    // 迭代處理集合中的元素

    each(obj, function(value, index, list) {

      // 將每次迭代處理的返回值存儲(chǔ)到results數(shù)組

      results[results.length] = iterator.call(context, value, index, list);

    });

    // 返回處理結(jié)果

    if(obj.length === +obj.length)

      results.length = obj.length;

    return results;

  };

  // 將集合中每個(gè)元素放入迭代處理器, 并將本次迭代的返回值作為"memo"傳遞到下一次迭代, 一般用于累計(jì)結(jié)果或連接數(shù)據(jù)

  _.reduce = _.foldl = _.inject = function(obj, iterator, memo, context) {

    // 通過參數(shù)數(shù)量檢查是否存在初始值

    var initial = arguments.length > 2;

    if(obj == null)

      obj = [];

    // 優(yōu)先調(diào)用宿主環(huán)境提供的reduce方法

    if(nativeReduce && obj.reduce === nativeReduce && false) {

      if(context)

        iterator = _.bind(iterator, context);

      return initial ? obj.reduce(iterator, memo) : obj.reduce(iterator);

    }

    // 迭代處理集合中的元素

    each(obj, function(value, index, list) {

      if(!initial) {

        // 如果沒有初始值, 則將第一個(gè)元素作為初始值; 如果被處理的是對(duì)象集合, 則默認(rèn)值為第一個(gè)屬性的值

        memo = value;

        initial = true;

      } else {

        // 記錄處理結(jié)果, 并將結(jié)果傳遞給下一次迭代

        memo = iterator.call(context, memo, value, index, list);

      }

    });

    if(!initial)

      throw new TypeError('Reduce of empty array with no initial value');

    return memo;

  };

  // 與reduce作用相似, 將逆向迭代集合中的元素(即從最后一個(gè)元素開始直到第一個(gè)元素)

  _.reduceRight = _.foldr = function(obj, iterator, memo, context) {

    var initial = arguments.length > 2;

    if(obj == null)

      obj = [];

    // 優(yōu)先調(diào)用宿主環(huán)境提供的reduceRight方法

    if(nativeReduceRight && obj.reduceRight === nativeReduceRight) {

      if(context)

        iterator = _.bind(iterator, context);

      return initial ? obj.reduceRight(iterator, memo) : obj.reduceRight(iterator);

    }

    // 逆轉(zhuǎn)集合中的元素順序

    var reversed = _.toArray(obj).reverse();

    if(context && !initial)

      iterator = _.bind(iterator, context);

    // 通過reduce方法處理數(shù)據(jù)

    return initial ? _.reduce(reversed, iterator, memo, context) : _.reduce(reversed, iterator);

  };

  // 遍歷集合中的元素, 返回第一個(gè)能夠通過處理器驗(yàn)證的元素

  _.find = _.detect = function(obj, iterator, context) {

    // result存放第一個(gè)能夠通過驗(yàn)證的元素

    var result;

    // 通過any方法遍歷數(shù)據(jù), 并記錄通過驗(yàn)證的元素

    // (如果是在迭代中檢查處理器返回狀態(tài), 這里使用each方法會(huì)更合適)

    any(obj, function(value, index, list) {

      // 如果處理器返回的結(jié)果被轉(zhuǎn)換為Boolean類型后值為true, 則當(dāng)前記錄并返回當(dāng)前元素

      if(iterator.call(context, value, index, list)) {

        result = value;

        return true;

      }

    });

    return result;

  };

  // 與find方法作用類似, 但filter方法會(huì)記錄下集合中所有通過驗(yàn)證的元素

  _.filter = _.select = function(obj, iterator, context) {

    // 用于存儲(chǔ)通過驗(yàn)證的元素?cái)?shù)組

    var results = [];

    if(obj == null)

      return results;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的filter方法

    if(nativeFilter && obj.filter === nativeFilter)

      return obj.filter(iterator, context);

    // 迭代集合中的元素, 并將通過處理器驗(yàn)證的元素放到數(shù)組中并返回

    each(obj, function(value, index, list) {

      if(iterator.call(context, value, index, list))

        results[results.length] = value;

    });

    return results;

  };

  // 與filter方法作用相反, 即返回沒有通過處理器驗(yàn)證的元素列表

  _.reject = function(obj, iterator, context) {

    var results = [];

    if(obj == null)

      return results;

    each(obj, function(value, index, list) {

      if(!iterator.call(context, value, index, list))

        results[results.length] = value;

    });

    return results;

  };

  // 如果集合中所有元素均能通過處理器驗(yàn)證, 則返回true

  _.every = _.all = function(obj, iterator, context) {

    var result = true;

    if(obj == null)

      return result;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的every方法

    if(nativeEvery && obj.every === nativeEvery)

      return obj.every(iterator, context);

    // 迭代集合中的元素

    each(obj, function(value, index, list) {

      // 這里理解為 result = (result && iterator.call(context, value, index, list))

      // 驗(yàn)證處理器的結(jié)果被轉(zhuǎn)換為Boolean類型后是否為true值

      if(!( result = result && iterator.call(context, value, index, list)))

        return breaker;

    });

    return !!result;

  };

  // 檢查集合中任何一個(gè)元素在被轉(zhuǎn)換為Boolean類型時(shí), 是否為true值?或者通過處理器處理后, 是否值為true?

  var any = _.some = _.any = function(obj, iterator, context) {

    // 如果沒有指定處理器參數(shù), 則默認(rèn)的處理器函數(shù)會(huì)返回元素本身, 并在迭代時(shí)通過將元素轉(zhuǎn)換為Boolean類型來(lái)判斷是否為true值

    iterator || ( iterator = _.identity);

    var result = false;

    if(obj == null)

      return result;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的some方法

    if(nativeSome && obj.some === nativeSome)

      return obj.some(iterator, context);

    // 迭代集合中的元素

    each(obj, function(value, index, list) {

      if(result || ( result = iterator.call(context, value, index, list)))

        return breaker;

    });

    return !!result;

  };

  // 檢查集合中是否有值與目標(biāo)參數(shù)完全匹配(同時(shí)將匹配數(shù)據(jù)類型)

  _.include = _.contains = function(obj, target) {

    var found = false;

    if(obj == null)

      return found;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的Array.prototype.indexOf方法

    if(nativeIndexOf && obj.indexOf === nativeIndexOf)

      return obj.indexOf(target) != -1;

    // 通過any方法迭代集合中的元素, 驗(yàn)證元素的值和類型與目標(biāo)是否完全匹配

    found = any(obj, function(value) {

      return value === target;

    });

    return found;

  };

  // 依次調(diào)用集合中所有元素的同名方法, 從第3個(gè)參數(shù)開始, 將被以此傳入到元素的調(diào)用方法中

  // 返回一個(gè)數(shù)組, 存儲(chǔ)了所有方法的處理結(jié)果

  _.invoke = function(obj, method) {

    // 調(diào)用同名方法時(shí)傳遞的參數(shù)(從第3個(gè)參數(shù)開始)

    var args = slice.call(arguments, 2);

    // 依次調(diào)用每個(gè)元素的方法, 并將結(jié)果放入數(shù)組中返回

    return _.map(obj, function(value) {

      return (_.isFunction(method) ? method || value : value[method]).apply(value, args);

    });

  };

  // 遍歷一個(gè)由對(duì)象列表組成的數(shù)組, 并返回每個(gè)對(duì)象中的指定屬性的值列表

  _.pluck = function(obj, key) {

    // 如果某一個(gè)對(duì)象中不存在該屬性, 則返回undefined

    return _.map(obj, function(value) {

      return value[key];

    });

  };

  // 返回集合中的最大值, 如果不存在可比較的值, 則返回undefined

  _.max = function(obj, iterator, context) {

    // 如果集合是一個(gè)數(shù)組, 且沒有使用處理器, 則使用Math.max獲取最大值

    // 一般會(huì)是在一個(gè)數(shù)組存儲(chǔ)了一系列Number類型的數(shù)據(jù)

    if(!iterator && _.isArray(obj) && obj[0] === +obj[0])

      return Math.max.apply(Math, obj);

    // 對(duì)于空值, 直接返回負(fù)無(wú)窮大

    if(!iterator && _.isEmpty(obj))

      return -Infinity;

    // 一個(gè)臨時(shí)的對(duì)象, computed用于在比較過程中存儲(chǔ)最大值(臨時(shí)的)

    var result = {

      computed : -Infinity

    };

    // 迭代集合中的元素

    each(obj, function(value, index, list) {

      // 如果指定了處理器參數(shù), 則比較的數(shù)據(jù)為處理器返回的值, 否則直接使用each遍歷時(shí)的默認(rèn)值

      var computed = iterator ? iterator.call(context, value, index, list) : value;

      // 如果比較值相比上一個(gè)值要大, 則將當(dāng)前值放入result.value

      computed >= result.computed && ( result = {

        value : value,

        computed : computed

      });

    });

    // 返回最大值

    return result.value;

  };

  // 返回集合中的最小值, 處理過程與max方法一致

  _.min = function(obj, iterator, context) {

    if(!iterator && _.isArray(obj) && obj[0] === +obj[0])

      return Math.min.apply(Math, obj);

    if(!iterator && _.isEmpty(obj))

      return Infinity;

    var result = {

      computed : Infinity

    };

    each(obj, function(value, index, list) {

      var computed = iterator ? iterator.call(context, value, index, list) : value;

      computed < result.computed && ( result = {

        value : value,

        computed : computed

      });

    });

    return result.value;

  };

  // 通過隨機(jī)數(shù), 讓數(shù)組無(wú)須排列

  _.shuffle = function(obj) {

    // shuffled變量存儲(chǔ)處理過程及最終的結(jié)果數(shù)據(jù)

    var shuffled = [], rand;

    // 迭代集合中的元素

    each(obj, function(value, index, list) {

      // 生成一個(gè)隨機(jī)數(shù), 隨機(jī)數(shù)在<0-當(dāng)前已處理的數(shù)量>之間

      rand = Math.floor(Math.random() * (index + 1));

      // 將已經(jīng)隨機(jī)得到的元素放到shuffled數(shù)組末尾

      shuffled[index] = shuffled[rand];

      // 在前面得到的隨機(jī)數(shù)的位置插入最新值

      shuffled[rand] = value;

    });

    // 返回一個(gè)數(shù)組, 該數(shù)組中存儲(chǔ)了經(jīng)過隨機(jī)混排的集合元素

    return shuffled;

  };

  // 對(duì)集合中元素, 按照特定的字段或值進(jìn)行排列

  // 相比Array.prototype.sort方法, sortBy方法支持對(duì)對(duì)象排序

  _.sortBy = function(obj, val, context) {

    // val應(yīng)該是對(duì)象的一個(gè)屬性, 或一個(gè)處理器函數(shù), 如果是一個(gè)處理器, 則應(yīng)該返回需要進(jìn)行比較的數(shù)據(jù)

    var iterator = _.isFunction(val) ? val : function(obj) {

      return obj[val];

    };

    // 調(diào)用順序: _.pluck(_.map().sort());

    // 調(diào)用_.map()方法遍歷集合, 并將集合中的元素放到value節(jié)點(diǎn), 將元素中需要進(jìn)行比較的數(shù)據(jù)放到criteria屬性中

    // 調(diào)用sort()方法將集合中的元素按照criteria屬性中的數(shù)據(jù)進(jìn)行順序排序

    // 調(diào)用pluck獲取排序后的對(duì)象集合并返回

    return _.pluck(_.map(obj, function(value, index, list) {

      return {

        value : value,

        criteria : iterator.call(context, value, index, list)

      };

    }).sort(function(left, right) {

      var a = left.criteria, b = right.criteria;

      if(a ===

        void 0)

        return 1;

      if(b ===

        void 0)

        return -1;

      return a < b ? -1 : a > b ? 1 : 0;

    }), 'value');

  };

  // 將集合中的元素, 按處理器返回的key分為多個(gè)數(shù)組

  _.groupBy = function(obj, val) {

    var result = {};

    // val將被轉(zhuǎn)換為進(jìn)行分組的處理器函數(shù), 如果val不是一個(gè)Function類型的數(shù)據(jù), 則將被作為篩選元素時(shí)的key值

    var iterator = _.isFunction(val) ? val : function(obj) {

      return obj[val];

    };

    // 迭代集合中的元素

    each(obj, function(value, index) {

      // 將處理器的返回值作為key, 并將相同的key元素放到一個(gè)新的數(shù)組

      var key = iterator(value, index);

      (result[key] || (result[key] = [])).push(value);

    });

    // 返回已分組的數(shù)據(jù)

    return result;

  };

  _.sortedIndex = function(array, obj, iterator) {

    iterator || ( iterator = _.identity);

    var low = 0, high = array.length;

    while(low < high) {

      var mid = (low + high) >> 1;

      iterator(array[mid]) < iterator(obj) ? low = mid + 1 : high = mid;

    }

    return low;

  };

  // 將一個(gè)集合轉(zhuǎn)換一個(gè)數(shù)組并返回

  // 一般用于將arguments轉(zhuǎn)換為數(shù)組, 或?qū)?duì)象無(wú)序集合轉(zhuǎn)換為數(shù)據(jù)形式的有序集合

  _.toArray = function(obj) {

    if(!obj)

      return [];

    if(_.isArray(obj))

      return slice.call(obj);

    // 將arguments轉(zhuǎn)換為數(shù)組

    if(_.isArguments(obj))

      return slice.call(obj);

    if(obj.toArray && _.isFunction(obj.toArray))

      return obj.toArray();

    // 將對(duì)象轉(zhuǎn)換為數(shù)組, 數(shù)組中包含對(duì)象中所有屬性的值列表(不包含對(duì)象原型鏈中的屬性)

    return _.values(obj);

  };

  // 計(jì)算集合中元素的數(shù)量

  _.size = function(obj) {

    // 如果集合是一個(gè)數(shù)組, 則計(jì)算數(shù)組元素?cái)?shù)量

    // 如果集合是一個(gè)對(duì)象, 則計(jì)算對(duì)象中的屬性數(shù)量(不包含對(duì)象原型鏈中的屬性)

    return _.isArray(obj) ? obj.length : _.keys(obj).length;

  };

  // 數(shù)組相關(guān)的方法

  // ---------------

 

  // 返回一個(gè)數(shù)組的第一個(gè)或順序指定的n個(gè)元素

  _.first = _.head = _.take = function(array, n, guard) {

    // 如果沒有指定參數(shù)n, 則返回第一個(gè)元素

    // 如果指定了n, 則返回一個(gè)新的數(shù)組, 包含順序指定數(shù)量n個(gè)元素

    // guard參數(shù)用于確定只返回第一個(gè)元素, 當(dāng)guard為true時(shí), 指定數(shù)量n無(wú)效

    return (n != null) && !guard ? slice.call(array, 0, n) : array[0];

  };

  // 返回一個(gè)新數(shù)組, 包含除第一個(gè)元素外的其它元素, 或排除從最后一個(gè)元素開始向前指定n個(gè)元素

  // 與first方法不同在于, first確定需要的元素在數(shù)組之前的位置, initial確定能排除的元素在數(shù)組最后的位置

  _.initial = function(array, n, guard) {

    // 如果沒有傳遞參數(shù)n, 則默認(rèn)返回除最后一個(gè)元素外的其它元素

    // 如果傳遞參數(shù)n, 則返回從最后一個(gè)元素開始向前的n個(gè)元素外的其它元素

    // guard用于確定只返回一個(gè)元素, 當(dāng)guard為true時(shí), 指定數(shù)量n無(wú)效

    return slice.call(array, 0, array.length - ((n == null) || guard ? 1 : n));

  };

  // 返回?cái)?shù)組的最后一個(gè)或倒序指定的n個(gè)元素

  _.last = function(array, n, guard) {

    if((n != null) && !guard) {

      // 計(jì)算并指定獲取的元素位置n, 直到數(shù)組末尾, 作為一個(gè)新的數(shù)組返回

      return slice.call(array, Math.max(array.length - n, 0));

    } else {

      // 如果沒有指定數(shù)量, 或guard為true時(shí), 只返回最后一個(gè)元素

      return array[array.length - 1];

    }

  };

  // 獲取除了第一個(gè)或指定前n個(gè)元素外的其它元素

  _.rest = _.tail = function(array, index, guard) {

    // 計(jì)算slice的第二個(gè)位置參數(shù), 直到數(shù)組末尾

    // 如果沒有指定index, 或guard值為true, 則返回除第一個(gè)元素外的其它元素

    // (index == null)值為true時(shí), 作為參數(shù)傳遞給slice函數(shù)將被自動(dòng)轉(zhuǎn)換為1

    return slice.call(array, (index == null) || guard ? 1 : index);

  };

  // 返回?cái)?shù)組中所有值能被轉(zhuǎn)換為true的元素, 返回一個(gè)新的數(shù)組

  // 不能被轉(zhuǎn)換的值包括 false, 0, '', null, undefined, NaN, 這些值將被轉(zhuǎn)換為false

  _.compact = function(array) {

    return _.filter(array, function(value) {

      return !!value;

    });

  };

  // 將一個(gè)多維數(shù)組合成為一維數(shù)組, 支持深層合并

  // shallow參數(shù)用于控制合并深度, 當(dāng)shallow為true時(shí), 只合并第一層, 默認(rèn)進(jìn)行深層合并

  _.flatten = function(array, shallow) {

    // 迭代數(shù)組中的每一個(gè)元素, 并將返回值作為demo傳遞給下一次迭代

    return _.reduce(array, function(memo, value) {

      // 如果元素依然是一個(gè)數(shù)組, 進(jìn)行以下判斷:

      // - 如果不進(jìn)行深層合并, 則使用Array.prototype.concat將當(dāng)前數(shù)組和之前的數(shù)據(jù)進(jìn)行連接

      // - 如果支持深層合并, 則迭代調(diào)用flatten方法, 直到底層元素不再是數(shù)組類型

      if(_.isArray(value))

        return memo.concat( shallow ? value : _.flatten(value));

      // 數(shù)據(jù)(value)已經(jīng)處于底層, 不再是數(shù)組類型, 則將數(shù)據(jù)合并到memo中并返回

      memo[memo.length] = value;

      return memo;

    }, []);

  };

  // 篩選并返回當(dāng)前數(shù)組中與指定數(shù)據(jù)不相等的差異數(shù)據(jù)(可參考difference方法注釋)

  _.without = function(array) {

    return _.difference(array, slice.call(arguments, 1));

  };

  // 對(duì)數(shù)組中的數(shù)據(jù)進(jìn)行去重(使用===進(jìn)行比較)

  // 當(dāng)isSorted參數(shù)不為false時(shí), 將依次對(duì)數(shù)組中的元素調(diào)用include方法, 檢查相同元素是否已經(jīng)被添加到返回值(數(shù)組)中

  // 如果調(diào)用之前確保數(shù)組中數(shù)據(jù)按順序排列, 則可以將isSorted設(shè)為true, 它將通過與最后一個(gè)元素進(jìn)行對(duì)比來(lái)排除相同值, 使用isSorted效率會(huì)高于默認(rèn)的include方式

  // uniq方法默認(rèn)將以數(shù)組中的數(shù)據(jù)進(jìn)行對(duì)比, 如果聲明iterator處理器, 則會(huì)根據(jù)處理器創(chuàng)建一個(gè)對(duì)比數(shù)組, 比較時(shí)以該數(shù)組中的數(shù)據(jù)為準(zhǔn), 但最終返回的唯一數(shù)據(jù)仍然是原始數(shù)組

  _.uniq = _.unique = function(array, isSorted, iterator) {

    // 如果使用了iterator處理器, 則先將當(dāng)前數(shù)組中的數(shù)據(jù)會(huì)先經(jīng)過按迭代器處理, 并返回一個(gè)處理后的新數(shù)組

    // 新數(shù)組用于作為比較的基準(zhǔn)

    var initial = iterator ? _.map(array, iterator) : array;

    // 用于記錄處理結(jié)果的臨時(shí)數(shù)組

    var results = [];

    // 如果數(shù)組中只有2個(gè)值, 則不需要使用include方法進(jìn)行比較, 將isSorted設(shè)置為true能提高運(yùn)行效率

    if(array.length < 3)

      isSorted = true;

    // 使用reduce方法迭代并累加處理結(jié)果

    // initial變量是需要進(jìn)行比較的基準(zhǔn)數(shù)據(jù), 它可能是原始數(shù)組, 也可能是處理器的結(jié)果集合(如果設(shè)置過iterator)

    _.reduce(initial, function(memo, value, index) {

      // 如果isSorted參數(shù)為true, 則直接使用===比較記錄中的最后一個(gè)數(shù)據(jù)

      // 如果isSorted參數(shù)為false, 則使用include方法與集合中的每一個(gè)數(shù)據(jù)進(jìn)行對(duì)比

      if( isSorted ? _.last(memo) !== value || !memo.length : !_.include(memo, value)) {

        // memo記錄了已經(jīng)比較過的無(wú)重復(fù)數(shù)據(jù)

        // 根據(jù)iterator參數(shù)的狀態(tài), memo中記錄的數(shù)據(jù)可能是原始數(shù)據(jù), 也可能是處理器處理后的數(shù)據(jù)

        memo.push(value);

        // 處理結(jié)果數(shù)組中保存的始終為原始數(shù)組中的數(shù)據(jù)

        results.push(array[index]);

      }

      return memo;

    }, []);

    // 返回處理結(jié)果, 它只包含數(shù)組中無(wú)重復(fù)的數(shù)據(jù)

    return results;

  };

  // union方法與uniq方法作用一致, 不同之處在于union允許在參數(shù)中傳入多個(gè)數(shù)組

  _.union = function() {

    // union對(duì)參數(shù)中的多個(gè)數(shù)組進(jìn)行淺層合并為一個(gè)數(shù)組對(duì)象傳遞給uniq方法進(jìn)行處理

    return _.uniq(_.flatten(arguments, true));

  };

  // 獲取當(dāng)前數(shù)組與其它一個(gè)或多個(gè)數(shù)組的交集元素

  // 從第二個(gè)參數(shù)開始為需要進(jìn)行比較的一個(gè)或多個(gè)數(shù)組

  _.intersection = _.intersect = function(array) {

    // rest變量記錄需要進(jìn)行比較的其它數(shù)組對(duì)象

    var rest = slice.call(arguments, 1);

    // 使用uniq方法去除當(dāng)前數(shù)組中的重復(fù)數(shù)據(jù), 避免重復(fù)計(jì)算

    // 對(duì)當(dāng)前數(shù)組的數(shù)據(jù)通過處理器進(jìn)行過濾, 并返回符合條件(比較相同元素)的數(shù)據(jù)

    return _.filter(_.uniq(array), function(item) {

      // 使用every方法驗(yàn)證每一個(gè)數(shù)組中都包含了需要對(duì)比的數(shù)據(jù)

      // 如果所有數(shù)組中均包含對(duì)比數(shù)據(jù), 則全部返回true, 如果任意一個(gè)數(shù)組沒有包含該元素, 則返回false

      return _.every(rest, function(other) {

        // other參數(shù)存儲(chǔ)了每一個(gè)需要進(jìn)行對(duì)比的數(shù)組

        // item存儲(chǔ)了當(dāng)前數(shù)組中需要進(jìn)行對(duì)比的數(shù)據(jù)

        // 使用indexOf方法搜索數(shù)組中是否存在該元素(可參考indexOf方法注釋)

        return _.indexOf(other, item) >= 0;

      });

    });

  };

  // 篩選并返回當(dāng)前數(shù)組中與指定數(shù)據(jù)不相等的差異數(shù)據(jù)

  // 該函數(shù)一般用于刪除數(shù)組中指定的數(shù)據(jù), 并得到刪除后的新數(shù)組

  // 該方法的作用與without相等, without方法參數(shù)形式上不允許數(shù)據(jù)被包含在數(shù)組中, 而difference方法參數(shù)形式上建議是數(shù)組(也可以和without使用相同形式的參數(shù))

  _.difference = function(array) {

    // 對(duì)第2個(gè)參數(shù)開始的所有參數(shù), 作為一個(gè)數(shù)組進(jìn)行合并(僅合并第一層, 而并非深層合并)

    // rest變量存儲(chǔ)驗(yàn)證數(shù)據(jù), 在本方法中用于與原數(shù)據(jù)對(duì)比

    var rest = _.flatten(slice.call(arguments, 1), true);

    // 對(duì)合并后的數(shù)組數(shù)據(jù)進(jìn)行過濾, 過濾條件是當(dāng)前數(shù)組中不包含參數(shù)指定的驗(yàn)證數(shù)據(jù)的內(nèi)容

    // 將符合過濾條件的數(shù)據(jù)組合為一個(gè)新的數(shù)組并返回

    return _.filter(array, function(value) {

      return !_.include(rest, value);

    });

  };

  // 將每個(gè)數(shù)組的相同位置的數(shù)據(jù)作為一個(gè)新的二維數(shù)組返回, 返回的數(shù)組長(zhǎng)度以傳入?yún)?shù)中最大的數(shù)組長(zhǎng)度為準(zhǔn), 其它數(shù)組的空白位置使用undefined填充

  // zip方法應(yīng)該包含多個(gè)參數(shù), 且每個(gè)參數(shù)應(yīng)該均為數(shù)組

  _.zip = function() {

    // 將參數(shù)轉(zhuǎn)換為數(shù)組, 此時(shí)args是一個(gè)二維數(shù)組

    var args = slice.call(arguments);

    // 計(jì)算每一個(gè)數(shù)組的長(zhǎng)度, 并返回其中最大長(zhǎng)度值

    var length = _.max(_.pluck(args, 'length'));

    // 依照最大長(zhǎng)度值創(chuàng)建一個(gè)新的空數(shù)組, 該數(shù)組用于存儲(chǔ)處理結(jié)果

    var results = new Array(length);

    // 循環(huán)最大長(zhǎng)度, 在每次循環(huán)將調(diào)用pluck方法獲取每個(gè)數(shù)組中相同位置的數(shù)據(jù)(依次從0到最后位置)

    // 將獲取到的數(shù)據(jù)存儲(chǔ)在一個(gè)新的數(shù)組, 放入results并返回

    for(var i = 0; i < length; i++)

    results[i] = _.pluck(args, "" + i);

    // 返回的結(jié)果是一個(gè)二維數(shù)組

    return results;

  };

  // 搜索一個(gè)元素在數(shù)組中首次出現(xiàn)的位置, 如果元素不存在則返回 -1

  // 搜索時(shí)使用 === 對(duì)元素進(jìn)行匹配

  _.indexOf = function(array, item, isSorted) {

    if(array == null)

      return -1;

    var i, l;

    if(isSorted) {

      i = _.sortedIndex(array, item);

      return array[i] === item ? i : -1;

    }

    // 優(yōu)先調(diào)用宿主環(huán)境提供的indexOf方法

    if(nativeIndexOf && array.indexOf === nativeIndexOf)

      return array.indexOf(item);

    // 循環(huán)并返回元素首次出現(xiàn)的位置

    for( i = 0, l = array.length; i < l; i++)

    if( i in array && array[i] === item)

      return i;

    // 沒有找到元素, 返回-1

    return -1;

  };

  // 返回一個(gè)元素在數(shù)組中最后一次出現(xiàn)的位置, 如果元素不存在則返回 -1

  // 搜索時(shí)使用 === 對(duì)元素進(jìn)行匹配

  _.lastIndexOf = function(array, item) {

    if(array == null)

      return -1;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的lastIndexOf方法

    if(nativeLastIndexOf && array.lastIndexOf === nativeLastIndexOf)

      return array.lastIndexOf(item);

    var i = array.length;

    // 循環(huán)并返回元素最后出現(xiàn)的位置

    while(i--)

    if( i in array && array[i] === item)

      return i;

    // 沒有找到元素, 返回-1

    return -1;

  };

  // 根據(jù)區(qū)間和步長(zhǎng), 生成一系列整數(shù), 并作為數(shù)組返回

  // start參數(shù)表示最小數(shù)

  // stop參數(shù)表示最大數(shù)

  // step參數(shù)表示生成多個(gè)數(shù)值之間的步長(zhǎng)值

  _.range = function(start, stop, step) {

    // 參數(shù)控制

    if(arguments.length <= 1) {

      // 如果沒有參數(shù), 則start = 0, stop = 0, 在循環(huán)中不會(huì)生成任何數(shù)據(jù), 將返回一個(gè)空數(shù)組

      // 如果有1個(gè)參數(shù), 則參數(shù)指定給stop, start = 0

      stop = start || 0;

      start = 0;

    }

    // 生成整數(shù)的步長(zhǎng)值, 默認(rèn)為1

    step = arguments[2] || 1;

 

    // 根據(jù)區(qū)間和步長(zhǎng)計(jì)算將生成的最大值

    var len = Math.max(Math.ceil((stop - start) / step), 0);

    var idx = 0;

    var range = new Array(len);

 

    // 生成整數(shù)列表, 并存儲(chǔ)到range數(shù)組

    while(idx < len) {

      range[idx++] = start;

      start += step;

    }

 

    // 返回列表結(jié)果

    return range;

  };

  // 函數(shù)相關(guān)方法

  // ------------------

 

  // 創(chuàng)建一個(gè)用于設(shè)置prototype的公共函數(shù)對(duì)象

  var ctor = function() {

  };

  // 為一個(gè)函數(shù)綁定執(zhí)行上下文, 任何情況下調(diào)用該函數(shù), 函數(shù)中的this均指向context對(duì)象

  // 綁定函數(shù)時(shí), 可以同時(shí)給函數(shù)傳遞調(diào)用形參

  _.bind = function bind(func, context) {

    var bound, args;

    // 優(yōu)先調(diào)用宿主環(huán)境提供的bind方法

    if(func.bind === nativeBind && nativeBind)

      return nativeBind.apply(func, slice.call(arguments, 1));

    // func參數(shù)必須是一個(gè)函數(shù)(Function)類型

    if(!_.isFunction(func))

      throw new TypeError;

    // args變量存儲(chǔ)了bind方法第三個(gè)開始的參數(shù)列表, 每次調(diào)用時(shí)都將傳遞給func函數(shù)

    args = slice.call(arguments, 2);

    return bound = function() {

      if(!(this instanceof bound))

        return func.apply(context, sargs.concat(slice.call(arguments)));

      ctor.prototype = func.prototype;

      var self = new ctor;

      var result = func.apply(self, args.concat(slice.call(arguments)));

      if(Object(result) === result)

        return result;

      return self;

    };

  };

  // 將指定的函數(shù), 或?qū)ο蟊旧淼乃泻瘮?shù)上下本綁定到對(duì)象本身, 被綁定的函數(shù)在被調(diào)用時(shí), 上下文對(duì)象始終指向?qū)ο蟊旧?

  // 該方法一般在處理對(duì)象事件時(shí)使用, 例如:

  // _(obj).bindAll(); // 或_(obj).bindAll('handlerClick');

  // document.addEventListener('click', obj.handlerClick);

  // 在handlerClick方法中, 上下文依然是obj對(duì)象

  _.bindAll = function(obj) {

    // 第二個(gè)參數(shù)開始表示需要綁定的函數(shù)名稱

    var funcs = slice.call(arguments, 1);

    // 如果沒有指定特定的函數(shù)名稱, 則默認(rèn)綁定對(duì)象本身所有類型為Function的屬性

    if(funcs.length == 0)

      funcs = _.functions(obj);

    // 循環(huán)并將所有的函數(shù)上下本設(shè)置為obj對(duì)象本身

    // each方法本身不會(huì)遍歷對(duì)象原型鏈中的方法, 但此處的funcs列表是通過_.functions方法獲取的, 它已經(jīng)包含了原型鏈中的方法

    each(funcs, function(f) {

      obj[f] = _.bind(obj[f], obj);

    });

    return obj;

  };

  // memoize方法將返回一個(gè)函數(shù), 該函數(shù)集成了緩存功能, 將經(jīng)過計(jì)算的值緩存到局部變量并在下次調(diào)用時(shí)直接返回

  // 如果計(jì)算結(jié)果是一個(gè)龐大的對(duì)象或數(shù)據(jù), 使用時(shí)應(yīng)該考慮內(nèi)存占用情況

  _.memoize = function(func, hasher) {

    // 用于存儲(chǔ)緩存結(jié)果的memo對(duì)象

    var memo = {};

    // hasher參數(shù)應(yīng)該是一個(gè)function, 它用于返回一個(gè)key, 該key作為讀取緩存的標(biāo)識(shí)

    // 如果沒有指定key, 則默認(rèn)使用函數(shù)的第一個(gè)參數(shù)作為key, 如果函數(shù)的第一個(gè)參數(shù)是復(fù)合數(shù)據(jù)類型, 可能會(huì)返回類似[Object object]的key, 這個(gè)key可能會(huì)造成后續(xù)計(jì)算的數(shù)據(jù)不正確

    hasher || ( hasher = _.identity);

    // 返回一個(gè)函數(shù), 該函數(shù)首先通過檢查緩存, 再對(duì)沒有緩存過的數(shù)據(jù)進(jìn)行調(diào)用

    return function() {

      var key = hasher.apply(this, arguments);

      return _.has(memo, key) ? memo[key] : (memo[key] = func.apply(this, arguments));

    };

  };

  // 延時(shí)執(zhí)行一個(gè)函數(shù)

  // wait單位為ms, 第3個(gè)參數(shù)開始將被依次傳遞給執(zhí)行函數(shù)

  _.delay = function(func, wait) {

    var args = slice.call(arguments, 2);

    return setTimeout(function() {

      return func.apply(null, args);

    }, wait);

  };

  // 延遲執(zhí)行函數(shù)

  // JavaScript中的setTimeout會(huì)被放到一個(gè)單獨(dú)的函數(shù)堆棧中執(zhí)行, 執(zhí)行時(shí)間是在當(dāng)前堆棧中調(diào)用的函數(shù)都被執(zhí)行完畢之后

  // defer設(shè)置函數(shù)在1ms后執(zhí)行, 目的是將func函數(shù)放到單獨(dú)的堆棧中, 等待當(dāng)前函數(shù)執(zhí)行完成后再執(zhí)行

  // defer方法一般用于處理DOM操作的優(yōu)先級(jí), 實(shí)現(xiàn)正確的邏輯流程和更流暢的交互體驗(yàn)

  _.defer = function(func) {

    return _.delay.apply(_, [func, 1].concat(slice.call(arguments, 1)));

  };

  // 函數(shù)節(jié)流方法, throttle方法主要用于控制函數(shù)的執(zhí)行頻率, 在被控制的時(shí)間間隔內(nèi), 頻繁調(diào)用函數(shù)不會(huì)被多次執(zhí)行

  // 在時(shí)間間隔內(nèi)如果多次調(diào)用了函數(shù), 時(shí)間隔截止時(shí)會(huì)自動(dòng)調(diào)用一次, 不需要等到時(shí)間截止后再手動(dòng)調(diào)用(自動(dòng)調(diào)用時(shí)不會(huì)有返回值)

  // throttle函數(shù)一般用于處理復(fù)雜和調(diào)用頻繁的函數(shù), 通過節(jié)流控制函數(shù)的調(diào)用頻率, 節(jié)省處理資源

  // 例如window.onresize綁定的事件函數(shù), 或element.onmousemove綁定的事件函數(shù), 可以用throttle進(jìn)行包裝

  // throttle方法返回一個(gè)函數(shù), 該函數(shù)會(huì)自動(dòng)調(diào)用func并進(jìn)行節(jié)流控制

  _.throttle = function(func, wait) {

    var context, args, timeout, throttling, more, result;

    // whenDone變量調(diào)用了debounce方法, 因此在多次連續(xù)調(diào)用函數(shù)時(shí), 最后一次調(diào)用會(huì)覆蓋之前調(diào)用的定時(shí)器, 清除狀態(tài)函數(shù)也僅會(huì)被執(zhí)行一次

    // whenDone函數(shù)在最后一次函數(shù)執(zhí)行的時(shí)間間隔截止時(shí)調(diào)用, 清除節(jié)流和調(diào)用過程中記錄的一些狀態(tài)

    var whenDone = _.debounce(function() {

      more = throttling = false;

    }, wait);

    // 返回一個(gè)函數(shù), 并在函數(shù)內(nèi)進(jìn)行節(jié)流控制

    return function() {

      // 保存函數(shù)的執(zhí)行上下文和參數(shù)

      context = this;

      args = arguments;

      // later函數(shù)在上一次函數(shù)調(diào)用時(shí)間間隔截止時(shí)執(zhí)行

      var later = function() {

        // 清除timeout句柄, 方便下一次函數(shù)調(diào)用

        timeout = null;

        // more記錄了在上一次調(diào)用至?xí)r間間隔截止之間, 是否重復(fù)調(diào)用了函數(shù)

        // 如果重復(fù)調(diào)用了函數(shù), 在時(shí)間間隔截止時(shí)將自動(dòng)再次調(diào)用函數(shù)

        if(more)

          func.apply(context, args);

        // 調(diào)用whenDone, 用于在時(shí)間間隔后清除節(jié)流狀態(tài)

        whenDone();

      };

      // timeout記錄了上一次函數(shù)執(zhí)行的時(shí)間間隔句柄

      // timeout時(shí)間間隔截止時(shí)調(diào)用later函數(shù), later中將清除timeout, 并檢查是否需要再次調(diào)用函數(shù)

      if(!timeout)

        timeout = setTimeout(later, wait);

      // throttling變量記錄上次調(diào)用的時(shí)間間隔是否已經(jīng)結(jié)束, 即是否處于節(jié)流過程中

      // throttling在每次函數(shù)調(diào)用時(shí)設(shè)為true, 表示需要進(jìn)行節(jié)流, 在時(shí)間間隔截止時(shí)設(shè)置為false(在whenDone函數(shù)中實(shí)現(xiàn))

      if(throttling) {

        // 節(jié)流過程中進(jìn)行了多次調(diào)用, 在more中記錄一個(gè)狀態(tài), 表示在時(shí)間間隔截止時(shí)需要再次自動(dòng)調(diào)用函數(shù)

        more = true;

      } else {

        // 沒有處于節(jié)流過程, 可能是第一次調(diào)用函數(shù), 或已經(jīng)超過上一次調(diào)用的間隔, 可以直接調(diào)用函數(shù)

        result = func.apply(context, args);

      }

      // 調(diào)用whenDone, 用于在時(shí)間間隔后清除節(jié)流狀態(tài)

      whenDone();

      // throttling變量記錄函數(shù)調(diào)用時(shí)的節(jié)流狀態(tài)

      throttling = true;

      // 返回調(diào)用結(jié)果

      return result;

    };

  };

  // debounce與throttle方法類似, 用于函數(shù)節(jié)流, 它們的不同之處在于:

  // -- throttle關(guān)注函數(shù)的執(zhí)行頻率, 在指定頻率內(nèi)函數(shù)只會(huì)被執(zhí)行一次;

  // -- debounce函數(shù)更關(guān)注函數(shù)執(zhí)行的間隔, 即函數(shù)兩次的調(diào)用時(shí)間不能小于指定時(shí)間;

  // 如果兩次函數(shù)的執(zhí)行間隔小于wait, 定時(shí)器會(huì)被清除并重新創(chuàng)建, 這意味著連續(xù)頻繁地調(diào)用函數(shù), 函數(shù)一直不會(huì)被執(zhí)行, 直到某一次調(diào)用與上一次調(diào)用的時(shí)間不小于wait毫秒

  // debounce函數(shù)一般用于控制需要一段時(shí)間之后才能執(zhí)行的操作, 例如在用戶輸入完畢200ms后提示用戶, 可以使用debounce包裝一個(gè)函數(shù), 綁定到onkeyup事件

  // ----------------------------------------------------------------

  // @param {Function} func 表示被執(zhí)行的函數(shù)

  // @param {Number} wait 表示允許的時(shí)間間隔, 在該時(shí)間范圍內(nèi)重復(fù)調(diào)用會(huì)被重新推遲wait毫秒

  // @param {Boolean} immediate 表示函數(shù)調(diào)用后是否立即執(zhí)行, true為立即調(diào)用, false為在時(shí)間截止時(shí)調(diào)用

  // debounce方法返回一個(gè)函數(shù), 該函數(shù)會(huì)自動(dòng)調(diào)用func并進(jìn)行節(jié)流控制

  _.debounce = function(func, wait, immediate) {

    // timeout用于記錄函數(shù)上一次調(diào)用的執(zhí)行狀態(tài)(定時(shí)器句柄)

    // 當(dāng)timeout為null時(shí), 表示上一次調(diào)用已經(jīng)結(jié)束

    var timeout;

    // 返回一個(gè)函數(shù), 并在函數(shù)內(nèi)進(jìn)行節(jié)流控制

    return function() {

      // 保持函數(shù)的上下文對(duì)象和參數(shù)

      var context = this, args = arguments;

      var later = function() {

        // 設(shè)置timeout為null

        // later函數(shù)會(huì)在允許的時(shí)間截止時(shí)被調(diào)用

        // 調(diào)用該函數(shù)時(shí), 表明上一次函數(shù)執(zhí)行時(shí)間已經(jīng)超過了約定的時(shí)間間隔, 此時(shí)之后再進(jìn)行調(diào)用都是被允許的

        timeout = null;

        if(!immediate)

          func.apply(context, args);

      };

      // 如果函數(shù)被設(shè)定為立即執(zhí)行, 且上一次調(diào)用的時(shí)間間隔已經(jīng)過去, 則立即調(diào)用函數(shù)

      if(immediate && !timeout)

        func.apply(context, args);

      // 創(chuàng)建一個(gè)定時(shí)器用于檢查和設(shè)置函數(shù)的調(diào)用狀態(tài)

      // 創(chuàng)建定時(shí)器之前先清空上一次setTimeout句柄, 無(wú)論上一次綁定的函數(shù)是否已經(jīng)被執(zhí)行

      // 如果本次函數(shù)在調(diào)用時(shí), 上一次函數(shù)執(zhí)行還沒有開始(一般是immediate設(shè)置為false時(shí)), 則函數(shù)的執(zhí)行時(shí)間會(huì)被推遲, 因此timeout句柄會(huì)被重新創(chuàng)建

      clearTimeout(timeout);

      // 在允許的時(shí)間截止時(shí)調(diào)用later函數(shù)

      timeout = setTimeout(later, wait);

    };

  };

  // 創(chuàng)建一個(gè)只會(huì)被執(zhí)行一次的函數(shù), 如果該函數(shù)被重復(fù)調(diào)用, 將返回第一次執(zhí)行的結(jié)果

  // 該函數(shù)用于獲取和計(jì)算固定數(shù)據(jù)的邏輯, 如獲取用戶所用的瀏覽器類型

  _.once = function(func) {

    // ran記錄函數(shù)是否被執(zhí)行過

    // memo記錄函數(shù)最后一次執(zhí)行的結(jié)果

    var ran = false, memo;

    return function() {

      // 如果函數(shù)已被執(zhí)行過, 則直接返回第一次執(zhí)行的結(jié)果

      if(ran)

        return memo;

      ran = true;

      return memo = func.apply(this, arguments);

    };

  };

  // 返回一個(gè)函數(shù), 該函數(shù)會(huì)將當(dāng)前函數(shù)作為參數(shù)傳遞給一個(gè)包裹函數(shù)

  // 在包裹函數(shù)中可以通過第一個(gè)參數(shù)調(diào)用當(dāng)前函數(shù), 并返回結(jié)果

  // 一般用于多個(gè)流程處理函數(shù)的低耦合組合調(diào)用

  _.wrap = function(func, wrapper) {

    return function() {

      // 將當(dāng)前函數(shù)作為第一個(gè)參數(shù), 傳遞給wrapper函數(shù)

      var args = [func].concat(slice.call(arguments, 0));

      // 返回wrapper函數(shù)的處理結(jié)果

      return wrapper.apply(this, args);

    };

  };

  // 將多個(gè)函數(shù)組合到一起, 按照參數(shù)傳遞的順序, 后一個(gè)函數(shù)的返回值會(huì)被一次作為參數(shù)傳遞給前一個(gè)函數(shù)作為參數(shù)繼續(xù)處理

  // _.compose(A, B, C); 等同于 A(B(C()));

  // 該方法的缺點(diǎn)在于被關(guān)聯(lián)的函數(shù)處理的參數(shù)數(shù)量只能有一個(gè), 如果需要傳遞多個(gè)參數(shù), 可以通過Array或Object復(fù)合數(shù)據(jù)類型進(jìn)行組裝

  _.compose = function() {

    // 獲取函數(shù)列表, 所有參數(shù)需均為Function類型

    var funcs = arguments;

    // 返回一個(gè)供調(diào)用的函數(shù)句柄

    return function() {

      // 從后向前依次執(zhí)行函數(shù), 并將記錄的返回值作為參數(shù)傳遞給前一個(gè)函數(shù)繼續(xù)處理

      var args = arguments;

      for(var i = funcs.length - 1; i >= 0; i--) {

        args = [funcs[i].apply(this, args)];

      }

      // 返回最后一次調(diào)用函數(shù)的返回值

      return args[0];

    };

  };

  // 返回一個(gè)函數(shù), 該函數(shù)作為調(diào)用計(jì)數(shù)器, 當(dāng)該函數(shù)被調(diào)用times次(或超過times次)后, func函數(shù)將被執(zhí)行

  // after方法一般用作異步的計(jì)數(shù)器, 例如在多個(gè)AJAX請(qǐng)求全部完成后需要執(zhí)行一個(gè)函數(shù), 則可以使用after在每個(gè)AJAX請(qǐng)求完成后調(diào)用

  _.after = function(times, func) {

    // 如果沒有指定或指定無(wú)效次數(shù), 則func被直接調(diào)用

    if(times <= 0)

      return func();

    // 返回一個(gè)計(jì)數(shù)器函數(shù)

    return function() {

      // 每次調(diào)用計(jì)數(shù)器函數(shù)times減1, 調(diào)用times次之后執(zhí)行func函數(shù)并返回func函數(shù)的返回值

      if(--times < 1) {

        return func.apply(this, arguments);

      }

    };

  };

  // 對(duì)象相關(guān)方法

  // ----------------

 

  // 獲取一個(gè)對(duì)象的屬性名列表(不包含原型鏈中的屬性)

  _.keys = nativeKeys ||

  function(obj) {

    if(obj !== Object(obj))

      throw new TypeError('Invalid object');

    var keys = [];

    // 記錄并返回對(duì)象的所有屬性名

    for(var key in obj)

    if(_.has(obj, key))

      keys[keys.length] = key;

    return keys;

  };

 

  // 返回一個(gè)對(duì)象中所有屬性的值列表(不包含原型鏈中的屬性)

  _.values = function(obj) {

    return _.map(obj, _.identity);

  };

  // 獲取一個(gè)對(duì)象中所有屬性值為Function類型的key列表, 并按key名進(jìn)行排序(包含原型鏈中的屬性)

  _.functions = _.methods = function(obj) {

    var names = [];

    for(var key in obj) {

      if(_.isFunction(obj[key]))

        names.push(key);

    }

    return names.sort();

  };

  // 將一個(gè)或多個(gè)對(duì)象的屬性(包含原型鏈中的屬性), 復(fù)制到obj對(duì)象, 如果存在同名屬性則覆蓋

  _.extend = function(obj) {

    // each循環(huán)參數(shù)中的一個(gè)或多個(gè)對(duì)象

    each(slice.call(arguments, 1), function(source) {

      // 將對(duì)象中的全部屬性復(fù)制或覆蓋到obj對(duì)象

      for(var prop in source) {

        obj[prop] = source[prop];

      }

    });

    return obj;

  };

  // 返回一個(gè)新對(duì)象, 并從obj中復(fù)制指定的屬性到新對(duì)象中

  // 第2個(gè)參數(shù)開始為指定的需要復(fù)制的屬性名(支持多個(gè)參數(shù)和深層數(shù)組)

  _.pick = function(obj) {

    // 創(chuàng)建一個(gè)對(duì)象, 存放復(fù)制的指定屬性

    var result = {};

    // 從第二個(gè)參數(shù)開始合并為一個(gè)存放屬性名列表的數(shù)組

    each(_.flatten(slice.call(arguments, 1)), function(key) {

      // 循環(huán)屬性名列表, 如果obj中存在該屬性, 則將其復(fù)制到result對(duì)象

      if( key in obj)

        result[key] = obj[key];

    });

    // 返回復(fù)制結(jié)果

    return result;

  };

  // 將obj中不存在或轉(zhuǎn)換為Boolean類型后值為false的屬性, 從參數(shù)中指定的一個(gè)或多個(gè)對(duì)象中復(fù)制到obj

  // 一般用于給對(duì)象指定默認(rèn)值

  _.defaults = function(obj) {

    // 從第二個(gè)參數(shù)開始可指定多個(gè)對(duì)象, 這些對(duì)象中的屬性將被依次復(fù)制到obj對(duì)象中(如果obj對(duì)象中不存在該屬性的話)

    each(slice.call(arguments, 1), function(source) {

      // 遍歷每個(gè)對(duì)象中的所有屬性

      for(var prop in source) {

        // 如果obj中不存在或?qū)傩灾缔D(zhuǎn)換為Boolean類型后值為false, 則將屬性復(fù)制到obj中

        if(obj[prop] == null)

          obj[prop] = source[prop];

      }

    });

    return obj;

  };

  // 創(chuàng)建一個(gè)obj的副本, 返回一個(gè)新的對(duì)象, 該對(duì)象包含obj中的所有屬性和值的狀態(tài)

  // clone函數(shù)不支持深層復(fù)制, 例如obj中的某個(gè)屬性存放著一個(gè)對(duì)象, 則該對(duì)象不會(huì)被復(fù)制

  // 如果obj是一個(gè)數(shù)組, 則會(huì)創(chuàng)建一個(gè)相同的數(shù)組對(duì)象

  _.clone = function(obj) {

    // 不支持非數(shù)組和對(duì)象類型的數(shù)據(jù)

    if(!_.isObject(obj))

      return obj;

    // 復(fù)制并返回?cái)?shù)組或?qū)ο?

    return _.isArray(obj) ? obj.slice() : _.extend({}, obj);

  };

  // 執(zhí)行一個(gè)函數(shù), 并將obj作為參數(shù)傳遞給該函數(shù), 函數(shù)執(zhí)行完畢后最終返回obj對(duì)象

  // 一般在創(chuàng)建一個(gè)方法鏈的時(shí)候會(huì)使用tap方法, 例如:

  // _(obj).chain().tap(click).tap(mouseover).tap(mouseout);

  _.tap = function(obj, interceptor) {

    interceptor(obj);

    return obj;

  };

  // eq函數(shù)只在isEqual方法中調(diào)用, 用于比較兩個(gè)數(shù)據(jù)的值是否相等

  // 與 === 不同在于, eq更關(guān)注數(shù)據(jù)的值

  // 如果進(jìn)行比較的是兩個(gè)復(fù)合數(shù)據(jù)類型, 不僅僅比較是否來(lái)自同一個(gè)引用, 且會(huì)進(jìn)行深層比較(對(duì)兩個(gè)對(duì)象的結(jié)構(gòu)和數(shù)據(jù)進(jìn)行比較)

  function eq(a, b, stack) {

    // 檢查兩個(gè)簡(jiǎn)單數(shù)據(jù)類型的值是否相等

    // 對(duì)于復(fù)合數(shù)據(jù)類型, 如果它們來(lái)自同一個(gè)引用, 則認(rèn)為其相等

    // 如果被比較的值其中包含0, 則檢查另一個(gè)值是否為-0, 因?yàn)?0 === -0 是成立的

    // 而 1 / 0 == 1 / -0 是不成立的(1 / 0值為Infinity, 1 / -0值為-Infinity, 而Infinity不等于-Infinity)

    if(a === b)

      return a !== 0 || 1 / a == 1 / b;

    // 將數(shù)據(jù)轉(zhuǎn)換為布爾類型后如果值為false, 將判斷兩個(gè)值的數(shù)據(jù)類型是否相等(因?yàn)閚ull與undefined, false, 0, 空字符串, 在非嚴(yán)格比較下值是相等的)

    if(a == null || b == null)

      return a === b;

    // 如果進(jìn)行比較的數(shù)據(jù)是一個(gè)Underscore封裝的對(duì)象(具有_chain屬性的對(duì)象被認(rèn)為是Underscore對(duì)象)

    // 則將對(duì)象解封后獲取本身的數(shù)據(jù)(通過_wrapped訪問), 然后再對(duì)本身的數(shù)據(jù)進(jìn)行比較

    // 它們的關(guān)系類似與一個(gè)jQuery封裝的DOM對(duì)象, 和瀏覽器本身創(chuàng)建的DOM對(duì)象

    if(a._chain)

      a = a._wrapped;

    if(b._chain)

      b = b._wrapped;

    // 如果對(duì)象提供了自定義的isEqual方法(此處的isEqual方法并非Undersocre對(duì)象的isEqual方法, 因?yàn)樵谏弦徊揭呀?jīng)對(duì)Undersocre對(duì)象進(jìn)行了解封)

    // 則使用對(duì)象自定義的isEqual方法與另一個(gè)對(duì)象進(jìn)行比較

    if(a.isEqual && _.isFunction(a.isEqual))

      return a.isEqual(b);

    if(b.isEqual && _.isFunction(b.isEqual))

      return b.isEqual(a);

    // 對(duì)兩個(gè)數(shù)據(jù)的數(shù)據(jù)類型進(jìn)行驗(yàn)證

    // 獲取對(duì)象a的數(shù)據(jù)類型(通過Object.prototype.toString方法)

    var className = toString.call(a);

    // 如果對(duì)象a的數(shù)據(jù)類型與對(duì)象b不匹配, 則認(rèn)為兩個(gè)數(shù)據(jù)值也不匹配

    if(className != toString.call(b))

      return false;

    // 執(zhí)行到此處, 可以確保需要比較的兩個(gè)數(shù)據(jù)均為復(fù)合數(shù)據(jù)類型, 且數(shù)據(jù)類型相等

    // 通過switch檢查數(shù)據(jù)的數(shù)據(jù)類型, 針對(duì)不同數(shù)據(jù)類型進(jìn)行不同的比較

    // (此處不包括對(duì)數(shù)組和對(duì)象類型, 因?yàn)樗鼈兛赡馨顚哟蔚臄?shù)據(jù), 將在后面進(jìn)行深層比較)

    switch (className) {

      case '[object String]':

        // 如果被比較的是字符串類型(其中a的是通過new String()創(chuàng)建的字符串)

        // 則將B轉(zhuǎn)換為String對(duì)象后進(jìn)行匹配(這里匹配并非進(jìn)行嚴(yán)格的數(shù)據(jù)類型檢查, 因?yàn)樗鼈儾⒎莵?lái)自同一個(gè)對(duì)象的引用)

        // 在調(diào)用 == 進(jìn)行比較時(shí), 會(huì)自動(dòng)調(diào)用對(duì)象的toString()方法, 返回兩個(gè)簡(jiǎn)單數(shù)據(jù)類型的字符串

        return a == String(b);

      case '[object Number]':

        // 通過+a將a轉(zhuǎn)成一個(gè)Number, 如果a被轉(zhuǎn)換之前與轉(zhuǎn)換之后不相等, 則認(rèn)為a是一個(gè)NaN類型

        // 因?yàn)镹aN與NaN是不相等的, 因此當(dāng)a值為NaN時(shí), 無(wú)法簡(jiǎn)單地使用a == b進(jìn)行匹配, 而是用相同的方法檢查b是否為NaN(即 b != +b)

        // 當(dāng)a值是一個(gè)非NaN的數(shù)據(jù)時(shí), 則檢查a是否為0, 因?yàn)楫?dāng)b為-0時(shí), 0 === -0是成立的(實(shí)際上它們?cè)谶壿嬌蠈儆趦蓚€(gè)不同的數(shù)據(jù))

        return a != +a ? b != +b : (a == 0 ? 1 / a == 1 / b : a == +b);

      case '[object Date]':

      // 對(duì)日期類型沒有使用return或break, 因此會(huì)繼續(xù)執(zhí)行到下一步(無(wú)論數(shù)據(jù)類型是否為Boolean類型, 因?yàn)橄乱徊綄?duì)Boolean類型進(jìn)行檢查)

      case '[object Boolean]':

        // 將日期或布爾類型轉(zhuǎn)換為數(shù)字

        // 日期類型將轉(zhuǎn)換為數(shù)值類型的時(shí)間戳(無(wú)效的日期格式將被換轉(zhuǎn)為NaN)

        // 布爾類型中, true被轉(zhuǎn)換為1, false被轉(zhuǎn)換為0

        // 比較兩個(gè)日期或布爾類型被轉(zhuǎn)換為數(shù)字后是否相等

        return +a == +b;

      case '[object RegExp]':

        // 正則表達(dá)式類型, 通過source訪問表達(dá)式的字符串形式

        // 檢查兩個(gè)表達(dá)式的字符串形式是否相等

        // 檢查兩個(gè)表達(dá)式的全局屬性是否相同(包括g, i, m)

        // 如果完全相等, 則認(rèn)為兩個(gè)數(shù)據(jù)相等

        return a.source == b.source && a.global == b.global && a.multiline == b.multiline && a.ignoreCase == b.ignoreCase;

    }

    // 當(dāng)執(zhí)行到此時(shí), ab兩個(gè)數(shù)據(jù)應(yīng)該為類型相同的對(duì)象或數(shù)組類型

    if( typeof a != 'object' || typeof b != 'object')

      return false;

    // stack(堆)是在isEqual調(diào)用eq函數(shù)時(shí)內(nèi)部傳遞的空數(shù)組, 在后面比較對(duì)象和數(shù)據(jù)的內(nèi)部迭代中調(diào)用eq方法也會(huì)傳遞

    // length記錄堆的長(zhǎng)度

    var length = stack.length;

    while(length--) {

      // 如果堆中的某個(gè)對(duì)象與數(shù)據(jù)a匹配, 則認(rèn)為相等

      if(stack[length] == a)

        return true;

    }

    // 將數(shù)據(jù)a添加到堆中

    stack.push(a);

    // 定義一些局部變量

    var size = 0, result = true;

    // 通過遞歸深層比較對(duì)象和數(shù)組

    if(className == '[object Array]') {

      // 被比較的數(shù)據(jù)為數(shù)組類型

      // size記錄數(shù)組的長(zhǎng)度

      // result比較兩個(gè)數(shù)組的長(zhǎng)度是否一致, 如果長(zhǎng)度不一致, 則方法的最后將返回result(即false)

      size = a.length;

      result = size == b.length;

      // 如果兩個(gè)數(shù)組的長(zhǎng)度一致

      if(result) {

        // 調(diào)用eq方法對(duì)數(shù)組中的元素進(jìn)行迭代比較(如果數(shù)組中包含二維數(shù)組或?qū)ο? eq方法會(huì)進(jìn)行深層比較)

        while(size--) {

          // 在確保兩個(gè)數(shù)組都存在當(dāng)前索引的元素時(shí), 調(diào)用eq方法深層比較(將堆數(shù)據(jù)傳遞給eq方法)

          // 將比較的結(jié)果存儲(chǔ)到result變量, 如果result為false(即在比較中得到某個(gè)元素的數(shù)據(jù)不一致), 則停止迭代

          if(!( result = size in a == size in b && eq(a[size], b[size], stack)))

            break;

        }

      }

    } else {

      // 被比較的數(shù)據(jù)為對(duì)象類型

      // 如果兩個(gè)對(duì)象不是同一個(gè)類的實(shí)例(通過constructor屬性比較), 則認(rèn)為兩個(gè)對(duì)象不相等

      if('constructor' in a != 'constructor' in b || a.constructor != b.constructor)

        return false;

      // 深層比較兩個(gè)對(duì)象中的數(shù)據(jù)

      for(var key in a) {

        if(_.has(a, key)) {

          // size用于記錄比較過的屬性數(shù)量, 因?yàn)檫@里遍歷的是a對(duì)象的屬性, 并比較b對(duì)象中該屬性的數(shù)據(jù)

          // 當(dāng)b對(duì)象中的屬性數(shù)量多余a對(duì)象時(shí), 此處的邏輯成立, 但兩個(gè)對(duì)象并不相等

          size++;

          // 迭代調(diào)用eq方法, 深層比較兩個(gè)對(duì)象中的屬性值

          // 將比較的結(jié)果記錄到result變量, 當(dāng)比較到不相等的數(shù)據(jù)時(shí)停止迭代

          if(!( result = _.has(b, key) && eq(a[key], b[key], stack)))

            break;

        }

      }

      // 深層比較完畢, 這里已經(jīng)可以確保在對(duì)象a中的所有數(shù)據(jù), 對(duì)象b中也存在相同的數(shù)據(jù)

      // 根據(jù)size(對(duì)象屬性長(zhǎng)度)檢查對(duì)象b中的屬性數(shù)量是否與對(duì)象a相等

      if(result) {

        // 遍歷對(duì)象b中的所有屬性

        for(key in b) {

          // 當(dāng)size已經(jīng)到0時(shí)(即對(duì)象a中的屬性數(shù)量已經(jīng)遍歷完畢), 而對(duì)象b中還存在有屬性, 則對(duì)象b中的屬性多于對(duì)象a

          if(_.has(b, key) && !(size--))

            break;

        }

        // 當(dāng)對(duì)象b中的屬性多于對(duì)象a, 則認(rèn)為兩個(gè)對(duì)象不相等

        result = !size;

      }

    }

    // 函數(shù)執(zhí)行完畢時(shí), 從堆中移除第一個(gè)數(shù)據(jù)(在比較對(duì)象或數(shù)組時(shí), 會(huì)迭代eq方法, 堆中可能存在多個(gè)數(shù)據(jù))

    stack.pop();

    // 返回的result記錄了最終的比較結(jié)果

    return result;

  }

 

  // 對(duì)兩個(gè)數(shù)據(jù)的值進(jìn)行比較(支持復(fù)合數(shù)據(jù)類型), 內(nèi)部函數(shù)eq的外部方法

  _.isEqual = function(a, b) {

    return eq(a, b, []);

  };

  // 檢查數(shù)據(jù)是否為空值, 包含'', false, 0, null, undefined, NaN, 空數(shù)組(數(shù)組長(zhǎng)度為0)和空對(duì)象(對(duì)象本身沒有任何屬性)

  _.isEmpty = function(obj) {

    // obj被轉(zhuǎn)換為Boolean類型后值為false

    if(obj == null)

      return true;

    // 檢查對(duì)象或字符串長(zhǎng)度是否為0

    if(_.isArray(obj) || _.isString(obj))

      return obj.length === 0;

    // 檢查對(duì)象(使用for in循環(huán)時(shí)將首先循環(huán)對(duì)象本身的屬性, 其次是原型鏈中的屬性), 因此如果第一個(gè)屬性是屬于對(duì)象本身的, 那么該對(duì)象不是一個(gè)空對(duì)象

    for(var key in obj)

    if(_.has(obj, key))

      return false;

    // 所有數(shù)據(jù)類型均沒有通過驗(yàn)證, 是一個(gè)空數(shù)據(jù)

    return true;

  };

  // 驗(yàn)證對(duì)象是否是一個(gè)DOM對(duì)象

  _.isElement = function(obj) {

    return !!(obj && obj.nodeType == 1);

  };

  // 驗(yàn)證對(duì)象是否是一個(gè)數(shù)組類型, 優(yōu)先調(diào)用宿主環(huán)境提供的isArray方法

  _.isArray = nativeIsArray ||

  function(obj) {

    return toString.call(obj) == '[object Array]';

  };

 

  // 驗(yàn)證對(duì)象是否是一個(gè)復(fù)合數(shù)據(jù)類型的對(duì)象(即非基本數(shù)據(jù)類型String, Boolean, Number, null, undefined)

  // 如果基本數(shù)據(jù)類型通過new進(jìn)行創(chuàng)建, 則也屬于對(duì)象類型

  _.isObject = function(obj) {

    return obj === Object(obj);

  };

  // 檢查一個(gè)數(shù)據(jù)是否是一個(gè)arguments參數(shù)對(duì)象

  _.isArguments = function(obj) {

    return toString.call(obj) == '[object Arguments]';

  };

  // 驗(yàn)證isArguments函數(shù), 如果運(yùn)行環(huán)境無(wú)法正常驗(yàn)證arguments類型的數(shù)據(jù), 則重新定義isArguments方法

  if(!_.isArguments(arguments)) {

    // 對(duì)于環(huán)境無(wú)法通過toString驗(yàn)證arguments類型的, 則通過調(diào)用arguments獨(dú)有的callee方法來(lái)進(jìn)行驗(yàn)證

    _.isArguments = function(obj) {

      // callee是arguments的一個(gè)屬性, 指向?qū)rguments所屬函數(shù)自身的引用

      return !!(obj && _.has(obj, 'callee'));

    };

  }

 

  // 驗(yàn)證對(duì)象是否是一個(gè)函數(shù)類型

  _.isFunction = function(obj) {

    return toString.call(obj) == '[object Function]';

  };

  // 驗(yàn)證對(duì)象是否是一個(gè)字符串類型

  _.isString = function(obj) {

    return toString.call(obj) == '[object String]';

  };

  // 驗(yàn)證對(duì)象是否是一個(gè)數(shù)字類型

  _.isNumber = function(obj) {

    return toString.call(obj) == '[object Number]';

  };

  // 檢查一個(gè)數(shù)字是否為有效數(shù)字且有效范圍(Number類型, 值在負(fù)無(wú)窮大 - 正無(wú)窮大之間)

  _.isFinite = function(obj) {

    return _.isNumber(obj) && isFinite(obj);

  };

  // 檢查數(shù)據(jù)是否為NaN類型(所有數(shù)據(jù)中只有NaN與NaN不相等)

  _.isNaN = function(obj) {

    return obj !== obj;

  };

  // 檢查數(shù)據(jù)是否時(shí)Boolean類型

  _.isBoolean = function(obj) {

    // 支持字面量和對(duì)象形式的Boolean數(shù)據(jù)

    return obj === true || obj === false || toString.call(obj) == '[object Boolean]';

  };

  // 檢查數(shù)據(jù)是否是一個(gè)Date類型

  _.isDate = function(obj) {

    return toString.call(obj) == '[object Date]';

  };

  // 檢查數(shù)據(jù)是否是一個(gè)正則表達(dá)式類型

  _.isRegExp = function(obj) {

    return toString.call(obj) == '[object RegExp]';

  };

  // 檢查數(shù)據(jù)是否是Null值

  _.isNull = function(obj) {

    return obj === null;

  };

  // 檢查數(shù)據(jù)是否是Undefined(未定義的)值

  _.isUndefined = function(obj) {

    return obj ===

    void 0;

  };

  // 檢查一個(gè)屬性是否屬于對(duì)象本身, 而非原型鏈中

  _.has = function(obj, key) {

    return hasOwnProperty.call(obj, key);

  };

  // 工具函數(shù)

  // -----------------

 

  // 放棄_(下劃線)命名的Underscore對(duì)象, 并返回Underscore對(duì)象, 一般用于避免命名沖突或規(guī)范命名方式

  // 例如:

  // var us = _.noConflict(); // 取消_(下劃線)命名, 并將Underscore對(duì)象存放于us變量中

  // console.log(_); // _(下劃線)已經(jīng)無(wú)法再訪問Underscore對(duì)象, 而恢復(fù)為Underscore定義前的值

  _.noConflict = function() {

    // previousUnderscore變量記錄了Underscore定義前_(下劃線)的值

    root._ = previousUnderscore;

    return this;

  };

  // 返回與參數(shù)相同的值, 一般用于將一個(gè)數(shù)據(jù)的獲取方式轉(zhuǎn)換為函數(shù)獲取方式(內(nèi)部用于構(gòu)建方法時(shí)作為默認(rèn)處理器函數(shù))

  _.identity = function(value) {

    return value;

  };

  // 使指定的函數(shù)迭代執(zhí)行n次(無(wú)參數(shù))

  _.times = function(n, iterator, context) {

    for(var i = 0; i < n; i++)

    iterator.call(context, i);

  };

  // 將HTML字符串中的特殊字符轉(zhuǎn)換為HTML實(shí)體, 包含 & < > " ' \

  _.escape = function(string) {

    return ('' + string).replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"').replace(/'/g, ''').replace(/\//g, '/');

  };

  // 指定一個(gè)對(duì)象的屬性, 返回該屬性對(duì)應(yīng)的值, 如果該屬性對(duì)應(yīng)的是一個(gè)函數(shù), 則會(huì)執(zhí)行該函數(shù)并返回結(jié)果

  _.result = function(object, property) {

    if(object == null)

      return null;

    // 獲取對(duì)象的值

    var value = object[property];

    // 如果值是一個(gè)函數(shù), 則執(zhí)行并返回, 否則將直接返回

    return _.isFunction(value) ? value.call(object) : value;

  };

  // 添加一系列自定義方法到Underscore對(duì)象中, 用于擴(kuò)展Underscore插件

  _.mixin = function(obj) {

    // obj是一個(gè)集合一系列自定義方法的對(duì)象, 此處通過each遍歷對(duì)象的方法

    each(_.functions(obj), function(name) {

      // 通過addToWrapper函數(shù)將自定義方法添加到Underscore構(gòu)建的對(duì)象中, 用于支持對(duì)象式調(diào)用

      // 同時(shí)將方法添加到 _ 本身, 用于支持函數(shù)式調(diào)用

      addToWrapper(name, _[name] = obj[name]);

    });

  };

  // 獲取一個(gè)全局唯一標(biāo)識(shí), 標(biāo)識(shí)從0開始累加

  var idCounter = 0;

  // prefix表示標(biāo)識(shí)的前綴, 如果沒有指定前綴則直接返回標(biāo)識(shí), 一般用于給對(duì)象或DOM創(chuàng)建唯一ID

  _.uniqueId = function(prefix) {

    var id = idCounter++;

    return prefix ? prefix + id : id;

  };

  // 定義模板的界定符號(hào), 在template方法中使用

  _.templateSettings = {

    // JavaScript可執(zhí)行代碼的界定符

    evaluate : /<%([\s\S]+?)%>/g,

    // 直接輸出變量的界定符

    interpolate : /<%=([\s\S]+?)%>/g,

    // 需要將HTML輸出為字符串(將特殊符號(hào)轉(zhuǎn)換為字符串形式)的界定符

    escape : /<%-([\s\S]+?)%>/g

  };

 

  var noMatch = /.^/;

 

  // escapes對(duì)象記錄了需要進(jìn)行相互換轉(zhuǎn)的特殊符號(hào)與字符串形式的對(duì)應(yīng)關(guān)系, 在兩者進(jìn)行相互轉(zhuǎn)換時(shí)作為索引使用

  // 首先根據(jù)字符串形式定義特殊字符

  var escapes = {

    '\\' : '\\',

    "'" : "'",

    'r' : '\r',

    'n' : '\n',

    't' : '\t',

    'u2028' : '\u2028',

    'u2029' : '\u2029'

  };

  // 遍歷所有特殊字符字符串, 并以特殊字符作為key記錄字符串形式

  for(var p in escapes)

  escapes[escapes[p]] = p;

  // 定義模板中需要替換的特殊符號(hào), 包含反斜杠, 單引號(hào), 回車符, 換行符, 制表符, 行分隔符, 段落分隔符

  // 在將字符串中的特殊符號(hào)轉(zhuǎn)換為字符串形式時(shí)使用

  var escaper = /\\|'|\r|\n|\t|\u2028|\u2029/g;

  // 在將字符串形式的特殊符號(hào)進(jìn)行反轉(zhuǎn)(替換)時(shí)使用

  var unescaper = /\\(\\|'|r|n|t|u2028|u2029)/g;

 

  // 反轉(zhuǎn)字符串中的特殊符號(hào)

  // 在模板中涉及到需要執(zhí)行的JavaScript源碼, 需要進(jìn)行特殊符號(hào)反轉(zhuǎn), 否則如果以HTML實(shí)體或字符串形式出現(xiàn), 會(huì)拋出語(yǔ)法錯(cuò)誤

  var unescape = function(code) {

    return code.replace(unescaper, function(match, escape) {

      return escapes[escape];

    });

  };

  // Underscore模板解析方法, 用于將數(shù)據(jù)填充到一個(gè)模板字符串中

  // 模板解析流程:

  // 1. 將模板中的特殊符號(hào)轉(zhuǎn)換為字符串

  // 2. 解析escape形式標(biāo)簽, 將內(nèi)容解析為HTML實(shí)體

  // 3. 解析interpolate形式標(biāo)簽, 輸出變量

  // 4. 解析evaluate形式標(biāo)簽, 創(chuàng)建可執(zhí)行的JavaScript代碼

  // 5. 生成一個(gè)處理函數(shù), 該函數(shù)在得到數(shù)據(jù)后可直接填充到模板并返回填充后的字符串

  // 6. 根據(jù)參數(shù)返回填充后的字符串或處理函數(shù)的句柄

  // -------------------

  // 在模板體內(nèi), 可通過argments獲取2個(gè)參數(shù), 分別為填充數(shù)據(jù)(名稱為obj)和Underscore對(duì)象(名稱為_)

  _.template = function(text, data, settings) {

    // 模板配置, 如果沒有指定配置項(xiàng), 則使用templateSettings中指定的配置項(xiàng)

    settings = _.defaults(settings || {}, _.templateSettings);

 

    // 開始將模板解析為可執(zhí)行源碼

    var source = "__p+='" + text.replace(escaper, function(match) {

      // 將特殊符號(hào)轉(zhuǎn)移為字符串形式

      return '\\' + escapes[match];

    }).replace(settings.escape || noMatch, function(match, code) {

      // 解析escape形式標(biāo)簽 <%- %>, 將變量中包含的HTML通過_.escape函數(shù)轉(zhuǎn)換為HTML實(shí)體

      return "'+\n_.escape(" + unescape(code) + ")+\n'";

    }).replace(settings.interpolate || noMatch, function(match, code) {

      // 解析interpolate形式標(biāo)簽 <%= %>, 將模板內(nèi)容作為一個(gè)變量與其它字符串連接起來(lái), 則會(huì)作為一個(gè)變量輸出

      return "'+\n(" + unescape(code) + ")+\n'";

    }).replace(settings.evaluate || noMatch, function(match, code) {

      // 解析evaluate形式標(biāo)簽 <% %>, evaluate標(biāo)簽中存儲(chǔ)了需要執(zhí)行的JavaScript代碼, 這里結(jié)束當(dāng)前的字符串拼接, 并在新的一行作為JavaScript語(yǔ)法執(zhí)行, 并將后面的內(nèi)容再次作為字符串的開始, 因此evaluate標(biāo)簽內(nèi)的JavaScript代碼就能被正常執(zhí)行

      return "';\n" + unescape(code) + "\n;__p+='";

    }) + "';\n";

    if(!settings.variable)

      source = 'with(obj||{}){\n' + source + '}\n';

    source = "var __p='';" + "var print=function(){__p+=Array.prototype.join.call(arguments, '')};\n" + source + "return __p;\n";

 

    // 創(chuàng)建一個(gè)函數(shù), 將源碼作為函數(shù)執(zhí)行體, 將obj和Underscore作為參數(shù)傳遞給該函數(shù)

    var render = new Function(settings.variable || 'obj', '_', source);

    // 如果指定了模板的填充數(shù)據(jù), 則替換模板內(nèi)容, 并返回替換后的結(jié)果

    if(data)

      return render(data, _);

    // 如果沒有指定填充數(shù)據(jù), 則返回一個(gè)函數(shù), 該函數(shù)用于將接收到的數(shù)據(jù)替換到模板

    // 如果在程序中會(huì)多次填充相同模板, 那么在第一次調(diào)用時(shí)建議不指定填充數(shù)據(jù), 在獲得處理函數(shù)的引用后, 再直接調(diào)用會(huì)提高運(yùn)行效率

    var template = function(data) {

      return render.call(this, data, _);

    };

    // 將創(chuàng)建的源碼字符串添加到函數(shù)對(duì)象中, 一般用于調(diào)試和測(cè)試

    template.source = 'function(' + (settings.variable || 'obj') + '){\n' + source + '}';

    // 沒有指定填充數(shù)據(jù)的情況下, 返回處理函數(shù)句柄

    return template;

  };

  // 支持Underscore對(duì)象的方法鏈操作, 可參考 wrapper.prototype.chain

  _.chain = function(obj) {

    return _(obj).chain();

  };

  // Underscore對(duì)象封裝相關(guān)方法

  // ---------------

 

  // 創(chuàng)建一個(gè)包裝器, 將一些原始數(shù)據(jù)進(jìn)行包裝

  // 所有的undersocre對(duì)象, 內(nèi)部均通過wrapper函數(shù)進(jìn)行構(gòu)造和封裝

  // Underscore與wrapper的內(nèi)部關(guān)系:

  // -內(nèi)部定義變量_, 將Underscore相關(guān)的方法添加到_, 這樣就可以支持函數(shù)式的調(diào)用, 如_.bind()

  // -內(nèi)部定義wrapper類, 將_的原型對(duì)象指向wrapper類的原型

  // -將Underscore相關(guān)的方法添加到wrapper原型, 創(chuàng)建的_對(duì)象就具備了Underscore的方法

  // -將Array.prototype相關(guān)方法添加到wrapper原型, 創(chuàng)建的_對(duì)象就具備了Array.prototype中的方法

  // -new _()時(shí)實(shí)際創(chuàng)建并返回了一個(gè)wrapper()對(duì)象, 并將原始數(shù)組存儲(chǔ)到_wrapped變量, 并將原始值作為第一個(gè)參數(shù)調(diào)用對(duì)應(yīng)方法

  var wrapper = function(obj) {

    // 原始數(shù)據(jù)存放在包裝對(duì)象的_wrapped屬性中

    this._wrapped = obj;

  };

  // 將Underscore的原型對(duì)象指向wrapper的原型, 因此通過像wrapper原型中添加方法, Underscore對(duì)象也會(huì)具備同樣的方法

  _.prototype = wrapper.prototype;

 

  // 返回一個(gè)對(duì)象, 如果當(dāng)前Underscore調(diào)用了chain()方法(即_chain屬性為true), 則返回一個(gè)被包裝的Underscore對(duì)象, 否則返回對(duì)象本身

  // result函數(shù)用于在構(gòu)造方法鏈時(shí)返回Underscore的包裝對(duì)象

  var result = function(obj, chain) {

    return chain ? _(obj).chain() : obj;

  };

  // 將一個(gè)自定義方法添加到Underscore對(duì)象中(實(shí)際是添加到wrapper的原型中, 而Underscore對(duì)象的原型指向了wrapper的原型)

  var addToWrapper = function(name, func) {

    // 向wrapper原型中添加一個(gè)name函數(shù), 該函數(shù)調(diào)用func函數(shù), 并支持了方法鏈的處理

    wrapper.prototype[name] = function() {

      // 獲取func函數(shù)的參數(shù), 并將當(dāng)前的原始數(shù)據(jù)添加到第一個(gè)參數(shù)

      var args = slice.call(arguments);

      unshift.call(args, this._wrapped);

      // 執(zhí)行函數(shù)并返回結(jié)果, 并通過result函數(shù)對(duì)方法鏈進(jìn)行封裝, 如果當(dāng)前調(diào)用了chain()方法, 則返回封裝后的Underscore對(duì)象, 否則返回對(duì)象本身

      return result(func.apply(_, args), this._chain);

    };

  };

  // 將內(nèi)部定義的_(下劃線, 即Underscore方法集合對(duì)象)中的方法復(fù)制到wrapper的原型鏈中(即Underscore的原型鏈中)

  // 這是為了在構(gòu)造對(duì)象式調(diào)用的Underscore對(duì)象時(shí), 這些對(duì)象也會(huì)具有內(nèi)部定義的Underscore方法

  _.mixin(_);

 

  // 將Array.prototype中的相關(guān)方法添加到Underscore對(duì)象中, 因此在封裝后的Underscore對(duì)象中也可以直接調(diào)用Array.prototype中的方法

  // 如: _([]).push()

  each(['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], function(name) {

    // 獲取Array.prototype中對(duì)應(yīng)方法的引用

    var method = ArrayProto[name];

    // 將該方法添加到Underscore對(duì)象中(實(shí)際是添加到wrapper的原型對(duì)象, 因此在創(chuàng)建Underscore對(duì)象時(shí)同時(shí)具備了該方法)

    wrapper.prototype[name] = function() {

      // _wrapped變量中存儲(chǔ)Underscore對(duì)象的原始值

      var wrapped = this._wrapped;

      // 調(diào)用Array對(duì)應(yīng)的方法并返回結(jié)果

      method.apply(wrapped, arguments);

      var length = wrapped.length;

      if((name == 'shift' || name == 'splice') && length === 0)

        delete wrapped[0];

      // 即使是對(duì)于Array中的方法, Underscore同樣支持方法鏈操作

      return result(wrapped, this._chain);

    };

  });

  // 作用同于上一段代碼, 將數(shù)組中的一些方法添加到Underscore對(duì)象, 并支持了方法鏈操作

  // 區(qū)別在于上一段代碼所添加的函數(shù), 均返回Array對(duì)象本身(也可能是封裝后的Array), concat, join, slice方法將返回一個(gè)新的Array對(duì)象(也可能是封裝后的Array)

  each(['concat', 'join', 'slice'], function(name) {

    var method = ArrayProto[name];

    wrapper.prototype[name] = function() {

      return result(method.apply(this._wrapped, arguments), this._chain);

    };

  });

  // 對(duì)Underscore對(duì)象進(jìn)行鏈?zhǔn)讲僮鞯穆暶鞣椒?

  wrapper.prototype.chain = function() {

    // this._chain用來(lái)標(biāo)示當(dāng)前對(duì)象是否使用鏈?zhǔn)讲僮?

    // 對(duì)于支持方法鏈操作的數(shù)據(jù), 一般在具體方法中會(huì)返回一個(gè)Underscore對(duì)象, 并將原始值存放在_wrapped屬性中, 也可以通過value()方法獲取原始值

    this._chain = true;

    return this;

  };

  // 返回被封裝的Underscore對(duì)象的原始值(存放在_wrapped屬性中)

  wrapper.prototype.value = function() {

    return this._wrapped;

  };

}).call(this);

相關(guān)文章

  • 淺析JavaScript中的事件機(jī)制

    淺析JavaScript中的事件機(jī)制

    這篇文章主要介紹了JavaScript中的事件機(jī)制,即JS與HTML的一般交互,需要的朋友可以參考下
    2015-06-06
  • 用js實(shí)現(xiàn)in_array的方法

    用js實(shí)現(xiàn)in_array的方法

    js沒有in_array函數(shù),但是我們可以自己給js寫一個(gè)in_array函數(shù)
    2013-11-11
  • ajax的hide隱藏問題解決方法

    ajax的hide隱藏問題解決方法

    我的頁(yè)面上有兩個(gè)table,調(diào)用ajax之后隱藏掉一個(gè),然后用html拼出另一個(gè)table,結(jié)果新的table最上面有個(gè)undefined,這個(gè)是怎么引起的
    2012-12-12
  • Javascript的this詳解

    Javascript的this詳解

    這篇文章主要介紹了Javascript的this的作用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • javaScript中

    javaScript中"=="和"==="的區(qū)別詳解

    對(duì)于JavaScript中比較運(yùn)算符,可能大家用的比較多的是“==”、對(duì)于“===”很多人可能很陌生。=== 表示恒等,首先比較兩邊的變量數(shù)據(jù)類型是否相等,其次比較兩邊的變量的數(shù)值是否相等;== 表示相等即僅僅比較兩邊變量的數(shù)值是否相等。
    2018-03-03
  • Javascript WebSocket使用實(shí)例介紹(簡(jiǎn)明入門教程)

    Javascript WebSocket使用實(shí)例介紹(簡(jiǎn)明入門教程)

    網(wǎng)絡(luò)套接字是下一代WEB應(yīng)用程序雙向通信技術(shù),它是基于一個(gè)獨(dú)立的socket并且需要客戶端瀏覽器支持HTML5
    2014-04-04
  • 詳細(xì)分析JS函數(shù)去抖和節(jié)流

    詳細(xì)分析JS函數(shù)去抖和節(jié)流

    這篇文章主要介紹了詳細(xì)分析JS函數(shù)去抖和節(jié)流相關(guān)知識(shí)以及代碼分析,需要的朋友學(xué)習(xí)參考下吧。
    2017-12-12
  • JavaScript中用于四舍五入的Math.round()方法講解

    JavaScript中用于四舍五入的Math.round()方法講解

    這篇文章主要介紹了JavaScript中用于四舍五入的Math.round()方法講解,是JS入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-06-06
  • ES6基礎(chǔ)語(yǔ)法之函數(shù)介紹

    ES6基礎(chǔ)語(yǔ)法之函數(shù)介紹

    這篇文章介紹了ES6中函數(shù)的用法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • JavaScript中property和attribute的區(qū)別詳細(xì)介紹

    JavaScript中property和attribute的區(qū)別詳細(xì)介紹

    這篇文章主要介紹了JavaScript中property和attribute的區(qū)別詳細(xì)介紹,本文總結(jié)了定義、相同這處、不同之處、瀏覽器兼容性上的差別等內(nèi)容,并建議優(yōu)先選擇property,需要的朋友可以參考下
    2015-03-03

最新評(píng)論

91成人精品亚洲国产| 精品一区二区三区三区88| 国产av福利网址大全| 欧美日本在线观看一区二区 | 精品国产在线手机在线| 精品高跟鞋丝袜一区二区| 亚洲欧美在线视频第一页| 欧美在线一二三视频| 一区二区三区精品日本| 老司机福利精品免费视频一区二区 | 欧美日韩人妻久久精品高清国产| 9国产精品久久久久老师| 亚洲精品高清自拍av| 在线观看av观看av| 欧美男同性恋69视频| 97小视频人妻一区二区| 熟女91pooyn熟女| av破解版在线观看| 日韩三级电影华丽的外出| 2019av在线视频| 日本熟妇丰满厨房55| 成人高潮aa毛片免费| 欧美日韩激情啪啪啪| 天天日天天干天天要| 快点插进来操我逼啊视频| 麻豆性色视频在线观看| 青青草国内在线视频精选| 中英文字幕av一区| 视频 一区二区在线观看| 欧洲欧美日韩国产在线| 亚洲欧美综合另类13p| av在线观看网址av| 日本中文字幕一二区视频| 日本av在线一区二区三区| av一区二区三区人妻| 亚洲成av人无码不卡影片一| 亚洲 图片 欧美 图片| 久草视频在线看免费| 国产午夜亚洲精品麻豆| tube69日本少妇| 亚洲国产第一页在线观看| 岛国毛片视频免费在线观看| 国产一级精品综合av| 香港三日本三韩国三欧美三级| 成人动漫大肉棒插进去视频| 国产精品人妻熟女毛片av久| 日本黄色三级高清视频| 女警官打开双腿沦为性奴| av天堂中文免费在线| 一区二区三区视频,福利一区二区| 欧美成人精品欧美一级黄色| 成人亚洲国产综合精品| 日本中文字幕一二区视频| 日本av高清免费网站| 中文字幕在线欧美精品| 一区二区三区毛片国产一区| 久草视频 久草视频2| 欧美性感尤物人妻在线免费看| 丝袜肉丝一区二区三区四区在线| 色综合久久无码中文字幕波多| jiujiure精品视频在线| 亚洲麻豆一区二区三区| av资源中文字幕在线观看| 亚洲 清纯 国产com| 狠狠鲁狠狠操天天晚上干干| 唐人色亚洲av嫩草| 中文字幕人妻一区二区视频| 人妻无码色噜噜狠狠狠狠色| 成人30分钟免费视频| 性欧美激情久久久久久久| 欧美精品国产综合久久| 欧美精品激情在线最新观看视频| 国产成人一区二区三区电影网站| 国产使劲操在线播放| 亚洲国产精品久久久久蜜桃| 青青草原网站在线观看| 在线国产精品一区二区三区| 欧美xxx成人在线| 日韩熟女系列一区二区三区| 亚洲精品av在线观看| 女蜜桃臀紧身瑜伽裤| 天堂av在线播放免费| 国产免费av一区二区凹凸四季| 国产熟妇一区二区三区av| 天天操夜夜骑日日摸| 青青伊人一精品视频| 少妇系列一区二区三区视频| 九色精品视频在线播放| 欧美成人综合视频一区二区 | 久久午夜夜伦痒痒想咳嗽P| 中文字幕+中文字幕| 少妇人妻100系列| 久久精品美女免费视频| 亚洲最大黄了色网站| 538精品在线观看视频| 国产又粗又硬又大视频| 视频一区 视频二区 视频| 天天操夜夜操天天操天天操| av高潮迭起在线观看| 亚洲av无乱一区二区三区性色| 色噜噜噜噜18禁止观看| 在线成人日韩av电影| 熟女视频一区,二区,三区| 欧美日韩高清午夜蜜桃大香蕉| 韩国AV无码不卡在线播放| 国产91久久精品一区二区字幕| av森泽佳奈在线观看| 人妻少妇av在线观看| 国产真实灌醉下药美女av福利| 中国熟女一区二区性xx| 狠狠操狠狠操免费视频| 伊人成人综合开心网| 色av色婷婷人妻久久久精品高清 | 欧美专区日韩专区国产专区| 久久人人做人人妻人人玩精品vr| yy96视频在线观看| 唐人色亚洲av嫩草| 日本三极片中文字幕| 喷水视频在线观看这里只有精品 | 欧美一区二区三区乱码在线播放| av中文在线天堂精品| 欧美伊人久久大香线蕉综合| 亚洲狠狠婷婷综合久久app | 女同性ⅹxx女同h偷拍| 91精品国产综合久久久蜜| 日本性感美女视频网站| 国产福利小视频免费观看| 青青青青在线视频免费观看| 亚洲欧美清纯唯美另类| 欧美精品中文字幕久久二区| 特级无码毛片免费视频播放| 欧美一级片免费在线成人观看| 亚洲综合色在线免费观看| 激情伦理欧美日韩中文字幕| 国产性生活中老年人视频网站| 日韩无码国产精品强奸乱伦| 狠狠操操操操操操操操操| 91精品国产麻豆国产| 2021天天色天天干| 综合国产成人在线观看| 男人在床上插女人视频| 自拍偷拍vs一区二区三区| 换爱交换乱高清大片| 欧美老鸡巴日小嫩逼| 特级欧美插插插插插bbbbb| 91片黄在线观看喷潮| 中国黄色av一级片| 成人午夜电影在线观看 久久| av网址在线播放大全| 日本人妻少妇18—xx| 最新的中文字幕 亚洲| 欧美区一区二区三视频| 日本高清成人一区二区三区| 欧美久久一区二区伊人| 中文人妻AV久久人妻水| 久久麻豆亚洲精品av| av手机免费在线观看高潮| 一区二区三区 自拍偷拍| 天码人妻一区二区三区在线看| 久久精品国产23696| 一级a看免费观看网站| 亚洲国际青青操综合网站| 91成人精品亚洲国产| 女同性ⅹxx女同h偷拍| 91香蕉成人app下载| 午夜免费观看精品视频| 在线 中文字幕 一区| 日韩美在线观看视频黄| 熟女91pooyn熟女| 人人妻人人人操人人人爽| 天天日天天干天天插舔舔| av一区二区三区人妻| v888av在线观看视频| 人人妻人人澡欧美91精品| 欧美黑人与人妻精品| 喷水视频在线观看这里只有精品| 欧美国品一二三产区区别| 欧美viboss性丰满| 欧美中国日韩久久精品| 亚洲无线观看国产高清在线| 女同互舔一区二区三区| 日韩黄色片在线观看网站| 欧美精品伦理三区四区| 欧亚乱色一区二区三区| 亚洲精品国偷自产在线观看蜜桃| 小泽玛利亚视频在线观看| av在线资源中文字幕| 成人av免费不卡在线观看| 天天日天天干天天爱| 十八禁在线观看地址免费| 亚洲第一黄色在线观看| www久久久久久久久久久| 天天日天天干天天干天天日| 黄色中文字幕在线播放| 国产成人一区二区三区电影网站| 大鸡八强奸视频在线观看| 久久久久国产成人精品亚洲午夜| 亚洲 欧美 精品 激情 偷拍| 久久久久久9999久久久久| av在线观看网址av| 青青青青青青草国产| 成人午夜电影在线观看 久久| 国产白袜脚足J棉袜在线观看| 女警官打开双腿沦为性奴| 亚洲激情偷拍一区二区 | 久久丁香花五月天色婷婷| 2018在线福利视频| 无码精品一区二区三区人| 欧美viboss性丰满| 午夜精品一区二区三区城中村| 青青尤物在线观看视频网站| 国产亚洲精品品视频在线| 欧美成一区二区三区四区| 可以在线观看的av中文字幕| 欲满人妻中文字幕在线| 国产精彩福利精品视频| 亚洲欧美激情人妻偷拍| 女生被男生插的视频网站| 福利一二三在线视频观看| 91传媒一区二区三区| 午夜精品久久久久久99热| 国产成人自拍视频播放| 99人妻视频免费在线| 欧美激情精品在线观看| 日本高清撒尿pissing| 内射久久久久综合网| 成人av中文字幕一区| 最近中文字幕国产在线| 日韩亚国产欧美三级涩爱| 亚洲乱码中文字幕在线| 国产精品熟女久久久久浪潮| 亚洲精品国产综合久久久久久久久| 中文字幕日韩无敌亚洲精品 | 女蜜桃臀紧身瑜伽裤 | 最近的中文字幕在线mv视频| 端庄人妻堕落挣扎沉沦| 国产午夜激情福利小视频在线| 亚洲精品无码久久久久不卡 | 香蕉aⅴ一区二区三区| 天天日天天爽天天干| 成人动漫大肉棒插进去视频| 青青青aaaa免费| 熟女在线视频一区二区三区| 天天操天天干天天插| 婷婷色国产黑丝少妇勾搭AV| 视频啪啪啪免费观看| 天天日夜夜干天天操| 亚洲成人国产综合一区| 经典av尤物一区二区| 蜜桃专区一区二区在线观看| 人人人妻人人澡人人| 免费看国产又粗又猛又爽又黄视频| 啊慢点鸡巴太大了啊舒服视频| 日本性感美女视频网站| 亚洲人妻国产精品综合| 久草视频首页在线观看| 亚洲成人国产综合一区| 午夜大尺度无码福利视频 | 欧美精品免费aaaaaa| 在线免费91激情四射 | 亚洲人妻国产精品综合| 久久香蕉国产免费天天| 久久热这里这里只有精品| 一区二区三区在线视频福利| 天天日天天添天天爽| 伊人情人综合成人久久网小说| 久久久久久久亚洲午夜综合福利| 三级av中文字幕在线观看| 亚洲 人妻 激情 中文| 美女骚逼日出水来了| 中文字幕中文字幕人妻| 日日夜夜精品一二三| 国产精品久久9999| 岛国免费大片在线观看| 婷婷久久一区二区字幕网址你懂得 | 亚洲1卡2卡三卡4卡在线观看| 人人妻人人爽人人添夜| 国产黄网站在线观看播放| 天天日天天摸天天爱| 精品一区二区三区在线观看| 91精品视频在线观看免费| 久久丁香婷婷六月天| 视频一区 视频二区 视频| 欧美伊人久久大香线蕉综合| 伊人日日日草夜夜草| 亚洲成人熟妇一区二区三区 | 美女少妇亚洲精选av| 日本熟妇一区二区x x| 久久午夜夜伦痒痒想咳嗽P| 欧美黄色录像免费看的| 亚洲激情av一区二区| 欧美精品黑人性xxxx| 在线免费观看亚洲精品电影| 一区二区三区的久久的蜜桃的视频| 亚洲av无硬久久精品蜜桃| 97瑟瑟超碰在线香蕉| 免费男阳茎伸入女阳道视频| 免费无毒热热热热热热久| 97国产在线观看高清| 97超碰国语国产97超碰| av亚洲中文天堂字幕网| 哥哥姐姐综合激情小说| 玩弄人妻熟妇性色av少妇| 青青青青青青青在线播放视频| 一区二区三区麻豆福利视频| 75国产综合在线视频| 大屁股肉感人妻中文字幕在线| 国产又粗又黄又硬又爽| 天天操天天射天天操天天天| 熟女人妻在线中出观看完整版| 亚洲 中文 自拍 另类 欧美| 香港三日本三韩国三欧美三级| 亚洲一区二区三区久久受| 天天干夜夜操啊啊啊| 白白操白白色在线免费视频 | 久久一区二区三区人妻欧美| 强行扒开双腿猛烈进入免费版| 日韩国产乱码中文字幕| 四川五十路熟女av| 人妻少妇亚洲精品中文字幕| 国产黄色高清资源在线免费观看| 国产日本欧美亚洲精品视| 天天干狠狠干天天操| 国产实拍勾搭女技师av在线| 日本美女性生活一级片| 91综合久久亚洲综合| 亚洲高清视频在线不卡| 专门看国产熟妇的网站| av乱码一区二区三区| 中文字幕高清资源站| 久久99久久99精品影院| 成人蜜桃美臀九一一区二区三区| 人妻丝袜诱惑我操她视频| 欧美一区二区中文字幕电影| 伊人日日日草夜夜草| 免费无码人妻日韩精品一区二区| 中文字幕 人妻精品| 青青草在观免费国产精品| 夏目彩春在线中文字幕| av老司机亚洲一区二区| 亚洲高清国产自产av| 国产在线免费观看成人| 欧美日本国产自视大全| 青青青青青青青在线播放视频| 精品美女在线观看视频在线观看| 欧美3p在线观看一区二区三区| 国产a级毛久久久久精品| av大全在线播放免费| 91破解版永久免费| 动漫美女的小穴视频| 中文字幕在线乱码一区二区| 大胸性感美女羞爽操逼毛片| 91九色国产熟女一区二区| 可以在线观看的av中文字幕| 爆乳骚货内射骚货内射在线| 国产亚州色婷婷久久99精品| 同居了嫂子在线播高清中文| 新97超碰在线观看| 天天干天天操天天插天天日| 国产chinesehd精品麻豆| 美洲精品一二三产区区别| 久草福利电影在线观看| 水蜜桃一区二区三区在线观看视频 | 天天日天天干天天搡| 中文亚洲欧美日韩无线码| 亚洲激情偷拍一区二区| 2020中文字幕在线播放| 欧美一区二区三区乱码在线播放| 国产福利在线视频一区| 亚洲激情av一区二区| 亚洲偷自拍高清视频| 人人妻人人人操人人人爽| 亚洲人人妻一区二区三区| 黑人解禁人妻叶爱071| 中文字幕日韩91人妻在线| av久久精品北条麻妃av观看| 少妇露脸深喉口爆吞精| 中文字幕乱码av资源| 免费看国产又粗又猛又爽又黄视频| 欧洲精品第一页欧洲精品亚洲| 成人综合亚洲欧美一区 | 日韩三级电影华丽的外出 | 天天射,天天操,天天说| 不卡精品视频在线观看| 中文字幕日韩人妻在线三区| 偷拍自拍亚洲视频在线观看| 国产麻豆剧传媒精品国产av蜜桃| 一区二区熟女人妻视频| 97少妇精品在线观看| www日韩毛片av| 国产又粗又猛又爽又黄的视频在线| 中文字幕奴隷色的舞台50| 欧美黑人性猛交xxxxⅹooo| 中文人妻AV久久人妻水| 国产熟妇人妻ⅹxxxx麻豆| 欧美美女人体视频一区| 中文字幕1卡1区2区3区| 亚洲图库另类图片区| 大鸡巴操b视频在线| 日韩激情文学在线视频| 天天操天天爽天天干| 日本欧美视频在线观看三区| 激情色图一区二区三区| 精品老妇女久久9g国产| 精品国产在线手机在线| 天天操天天干天天日狠狠插 | 粉嫩av蜜乳av蜜臀| 日韩成人免费电影二区| 日韩熟女系列一区二区三区| 一区二区三区美女毛片| chinese国产盗摄一区二区| 美女少妇亚洲精选av| 自拍偷拍日韩欧美一区二区| 天天插天天狠天天操| 亚洲人人妻一区二区三区| 久久精品亚洲国产av香蕉| 夜夜操,天天操,狠狠操| 久草视频中文字幕在线观看| 国产亚洲视频在线二区| 在线免费观看99视频| 97瑟瑟超碰在线香蕉| 日本人妻精品久久久久久| 亚洲欧美久久久久久久久| 黄色成人在线中文字幕| 亚洲1卡2卡三卡4卡在线观看 | 一区二区三区另类在线 | 色哟哟在线网站入口| av中文字幕在线导航| 中文字日产幕乱六区蜜桃| 免费人成黄页网站在线观看国产| 女同久久精品秋霞网| 日本性感美女视频网站| av天堂资源最新版在线看| 美女骚逼日出水来了| 欧美日韩中文字幕欧美| 黑人乱偷人妻中文字幕| 青青青艹视频在线观看| 在线免费观看黄页视频| 97超碰人人搞人人| 日本最新一二三区不卡在线| 不戴胸罩引我诱的隔壁的人妻| 999热精品视频在线| 全国亚洲男人的天堂| 日美女屁股黄邑视频| 1区2区3区不卡视频| 亚洲伊人久久精品影院一美女洗澡 | 男人和女人激情视频| 天天日天天透天天操| 91福利在线视频免费观看| 午夜在线观看岛国av,com| 香蕉91一区二区三区| 美女 午夜 在线视频| 亚洲中文字幕国产日韩| 91试看福利一分钟| 大香蕉大香蕉在线看| 制服丝袜在线人妻中文字幕| av在线观看网址av| 韩国女主播精品视频网站| 91人妻精品一区二区在线看| 福利在线视频网址导航| av中文字幕在线观看第三页| 99热久久这里只有精品| 日韩精品中文字幕播放| 日韩欧美国产一区不卡| 91国内视频在线观看| 日曰摸日日碰夜夜爽歪歪| 日韩人妻在线视频免费| jiuse91九色视频| 亚洲一区自拍高清免费视频| 在线观看免费视频网| 中国视频一区二区三区| 中文字幕高清资源站| 91成人精品亚洲国产| 激情五月婷婷免费视频| 美女吃鸡巴操逼高潮视频| 成人av久久精品一区二区| 欧美日韩情色在线观看| 日日夜夜精品一二三| 欧美少妇性一区二区三区| 久久精品亚洲成在人线a| 国产精品国产三级国产精东| 亚洲天堂av最新网址| 抽查舔水白紧大视频| 岛国黄色大片在线观看| 日韩熟女av天堂系列| 大尺度激情四射网站| 亚洲伊人色一综合网| av网址在线播放大全| 大鸡吧插逼逼视频免费看 | 亚洲va国产va欧美va在线| 在线免费观看黄页视频| 久久久久久久精品成人热| 午夜毛片不卡在线看| 91亚洲精品干熟女蜜桃频道| 2022天天干天天操| 91在线视频在线精品3| 免费费一级特黄真人片| 欧美在线一二三视频| 99婷婷在线观看视频| 在线观看的a站 最新| 美女吃鸡巴操逼高潮视频| 成人24小时免费视频| 日本av高清免费网站| 亚洲综合另类欧美久久| aaa久久久久久久久| 日韩欧美高清免费在线| 亚洲精品久久视频婷婷| 欧美伊人久久大香线蕉综合| 青娱乐在线免费视频盛宴| 大香蕉大香蕉大香蕉大香蕉大香蕉| av欧美网站在线观看| 亚洲熟妇久久无码精品| 午夜精品在线视频一区| 久久一区二区三区人妻欧美| 直接能看的国产av| 久久久久久久精品成人热| 日韩av有码一区二区三区4| 100%美女蜜桃视频| 护士小嫩嫩又紧又爽20p| 男人和女人激情视频| 青青青青青免费视频| 大香蕉伊人中文字幕| 亚洲一区二区三区uij| 国产精品国产精品一区二区| 绝顶痉挛大潮喷高潮无码| 国产精品久久久久久久精品视频| 色婷婷综合激情五月免费观看 | 超黄超污网站在线观看| 亚洲av无码成人精品区辽| 国产精品入口麻豆啊啊啊| yy96视频在线观看| 欧美精品免费aaaaaa| 国产麻豆剧传媒精品国产av蜜桃| 夜色撩人久久7777| 成年人的在线免费视频| 在线 中文字幕 一区| 一级黄片大鸡巴插入美女| 顶级尤物粉嫩小尤物网站| 自拍偷拍vs一区二区三区| 熟女人妻在线中出观看完整版| 天天日天天爽天天爽| 视频啪啪啪免费观看| av森泽佳奈在线观看| 亚洲欧美另类手机在线| 成年人啪啪视频在线观看| 国产一区二区火爆视频| 亚洲人成精品久久久久久久| 男生用鸡操女生视频动漫| 蜜桃视频在线欧美一区| 91九色porny蝌蚪国产成人| sspd152中文字幕在线| 欧美一级视频一区二区| 99精品久久久久久久91蜜桃| 精品一区二区三区午夜| 亚洲1卡2卡三卡4卡在线观看| 中文字幕av一区在线观看 | 最新激情中文字幕视频| 91人妻精品久久久久久久网站 | 亚洲青青操骚货在线视频| 黄色在线观看免费观看在线| 做爰视频毛片下载蜜桃视频1| 亚洲国际青青操综合网站| 国产亚洲天堂天天一区| 国产亚洲视频在线二区| 日本福利午夜电影在线观看| 蜜臀av久久久久久久| 国产黑丝高跟鞋视频在线播放| 欧美特色aaa大片| 国产精品一二三不卡带免费视频| 2022国产精品视频| 亚洲中文精品字幕在线观看| 中文字幕综合一区二区| 欧美偷拍亚洲一区二区| 日本少妇高清视频xxxxx| 免费十精品十国产网站| 国产美女精品福利在线| 日本韩国亚洲综合日韩欧美国产 | 在线观看的a站 最新| 青青伊人一精品视频| 欧洲国产成人精品91铁牛tv| 激情伦理欧美日韩中文字幕| 韩国亚洲欧美超一级在线播放视频| 日韩特级黄片高清在线看| 大学生A级毛片免费视频| 日本成人不卡一区二区| 日本三极片视频网站观看| 亚洲精品国品乱码久久久久| 色婷婷精品大在线观看| 午夜场射精嗯嗯啊啊视频| 欧美aa一级一区三区四区| 国产视频一区在线观看| 久久丁香婷婷六月天| 日本精品视频不卡一二三| 超pen在线观看视频公开97| 亚洲精品三级av在线免费观看| 青青青青青青草国产| 少妇人妻二三区视频| 99久久99一区二区三区| 五月色婷婷综合开心网4438| 人人妻人人爽人人添夜| 久久精品国产亚洲精品166m| 亚洲精品午夜久久久久| av中文字幕电影在线看| 国产精品女邻居小骚货| 91老熟女连续高潮对白| 天天干天天啪天天舔| 中文字幕综合一区二区| 88成人免费av网站| 成人免费毛片aaaa| 国产精品系列在线观看一区二区| 欧洲亚洲欧美日韩综合| 精品一区二区三区在线观看| 少妇被强干到高潮视频在线观看| 欧美日韩熟女一区二区三区| 亚洲日产av一区二区在线| 北条麻妃肉色丝袜视频| 亚洲天堂精品久久久| 国产午夜无码福利在线看| 亚洲视频乱码在线观看| 日韩欧美一级aa大片| 久久久久久九九99精品| 一个色综合男人天堂| 男人靠女人的逼视频| 一区二区麻豆传媒黄片| 天天射夜夜操狠狠干| 一区二区三区 自拍偷拍| 日韩北条麻妃一区在线| 综合页自拍视频在线播放| 国产精品人妻一区二区三区网站| 欧美香蕉人妻精品一区二区| 三级等保密码要求条款| 亚洲Av无码国产综合色区| 超碰97人人澡人人| 成人激情文学网人妻| 99精品免费久久久久久久久a| 亚洲成av人无码不卡影片一| 中文字幕第三十八页久久| 国产午夜亚洲精品不卡在线观看| 国产 在线 免费 精品| 91精品国产黑色丝袜| 国产黄色高清资源在线免费观看| 国产激情av网站在线观看| 97国产精品97久久| 777奇米久久精品一区| 国产极品美女久久久久久| 老司机欧美视频在线看| 欧美精品黑人性xxxx| 最新的中文字幕 亚洲| 深田咏美亚洲一区二区| 国产欧美日韩第三页| 国产性生活中老年人视频网站| 国产精品人妻熟女毛片av久| 五十路息与子猛烈交尾视频| 人妻无码色噜噜狠狠狠狠色| 北条麻妃肉色丝袜视频| 精品亚洲中文字幕av | 日本福利午夜电影在线观看| 91色网站免费在线观看| 国产一区二区欧美三区| 午夜精品一区二区三区4| 伊人精品福利综合导航| 日日夜夜精品一二三| 亚洲欧美人精品高清| 久久久久久久久久一区二区三区| 在线国产中文字幕视频| 亚洲成人黄色一区二区三区| 中文字幕综合一区二区| 经典国语激情内射视频| 亚洲 欧美 自拍 偷拍 在线| 国产刺激激情美女网站| 91高清成人在线视频| 大白屁股精品视频国产| 欧美国品一二三产区区别| 99国产精品窥熟女精品| 一区二区视频视频视频| 38av一区二区三区| 国产精品熟女久久久久浪潮| 国产成人无码精品久久久电影| 天堂av中文在线最新版| 成人精品在线观看视频| 欧美中文字幕一区最新网址| 国产成人精品亚洲男人的天堂| 亚洲视频在线观看高清| 三级av中文字幕在线观看| 亚洲高清国产拍青青草原| 懂色av蜜桃a v| av中文字幕电影在线看| 五十路老熟女码av| 丝袜长腿第一页在线| 女同性ⅹxx女同h偷拍| 天天想要天天操天天干| 日韩美在线观看视频黄| 日本阿v视频在线免费观看| 日韩在线视频观看有码在线| 黄色录像鸡巴插进去| 中文字幕1卡1区2区3区| 国产aⅴ一线在线观看| 国产va精品免费观看| 亚洲精品国产综合久久久久久久久| av日韩在线观看大全| 最新激情中文字幕视频| 五月天色婷婷在线观看视频免费| 精品区一区二区三区四区人妻| 丝袜美腿欧美另类 中文字幕| 欧美香蕉人妻精品一区二区| 中文字幕成人日韩欧美| 日本精品视频不卡一二三| 国产精品大陆在线2019不卡| 喷水视频在线观看这里只有精品| 中文字幕在线第一页成人 | 日韩欧美一级aa大片| 在线 中文字幕 一区| 99精品视频在线观看免费播放| 91av精品视频在线| av高潮迭起在线观看| 青草青永久在线视频18| 夜色17s精品人妻熟女| gav成人免费播放| 91国内精品自线在拍白富美| 久精品人妻一区二区三区| 国际av大片在线免费观看| 99精品久久久久久久91蜜桃| 色哟哟在线网站入口| 欧美一级色视频美日韩| 国产精彩福利精品视频| 曰本无码人妻丰满熟妇啪啪| 日韩影片一区二区三区不卡免费| 欧美日韩人妻久久精品高清国产| 亚洲男人的天堂a在线| 欧美日韩在线精品一区二区三| 国产精品精品精品999| 天天操天天干天天艹| 最近的中文字幕在线mv视频| 天天射,天天操,天天说| 少妇与子乱在线观看| 日本乱人一区二区三区| 日韩成人综艺在线播放| 日日操夜夜撸天天干| 天天日天天敢天天干| av在线观看网址av| 在线免费观看欧美小视频| 日韩亚国产欧美三级涩爱| 亚洲一区久久免费视频| 骚逼被大屌狂草视频免费看| 91av中文视频在线| 91国语爽死我了不卡| 亚洲Av无码国产综合色区| 欧美久久一区二区伊人| 综合激情网激情五月天| 欧美色呦呦最新网址| 亚洲欧美一区二区三区电影| av网址国产在线观看| 四川乱子伦视频国产vip| 人妻激情图片视频小说| 午夜场射精嗯嗯啊啊视频| 果冻传媒av一区二区三区| 天堂av在线官网中文| 97少妇精品在线观看| 成人国产小视频在线观看| 91久久精品色伊人6882| 久草极品美女视频在线观看| 亚洲激情,偷拍视频| 色婷婷久久久久swag精品| 98视频精品在线观看| 97精品成人一区二区三区| 中文字幕在线视频一区二区三区 | 91色老99久久九九爱精品| 欧美另类一区二区视频| 日日爽天天干夜夜操| 天天干天天日天天谢综合156| 国产夫妻视频在线观看免费 | 中文字幕av一区在线观看| 日韩美女综合中文字幕pp| 久青青草视频手机在线免费观看| 欧美成人综合视频一区二区| 九色porny九色9l自拍视频| 91精品啪在线免费| 国产综合高清在线观看| 亚洲的电影一区二区三区| 国产在线观看黄色视频| 在线观看亚洲人成免费网址| 久久精品视频一区二区三区四区 | 99热久久这里只有精品| 久久精品亚洲国产av香蕉| 大香蕉玖玖一区2区| 国产亚洲精品视频合集| 亚洲av在线观看尤物| 啊用力插好舒服视频| 同居了嫂子在线播高清中文| 日本www中文字幕| 免费av岛国天堂网站| 国产1区,2区,3区| 亚洲欧美清纯唯美另类| 性感美女高潮视频久久久| 喷水视频在线观看这里只有精品 | 中文字幕在线永久免费播放| 日本少妇高清视频xxxxx| 人妻av无码专区久久绿巨人| 91成人在线观看免费视频| 亚洲男人在线天堂网| 天天躁日日躁狠狠躁躁欧美av| 日韩美女搞黄视频免费| 97黄网站在线观看| 唐人色亚洲av嫩草| 福利一二三在线视频观看| 中文字幕午夜免费福利视频| 亚洲综合另类精品小说| 成人精品在线观看视频| 自拍偷区二区三区麻豆| 婷婷午夜国产精品久久久| 国产乱子伦精品视频潮优女| 精品国产午夜视频一区二区| 操的小逼流水的文章| 在线观看视频网站麻豆| 在线国产精品一区二区三区| 青青青青青操视频在线观看| 精品久久久久久久久久久99| 日韩在线中文字幕色| 国产黑丝高跟鞋视频在线播放| 夏目彩春在线中文字幕| 国产精品大陆在线2019不卡| 一级黄片大鸡巴插入美女| 欧美一级色视频美日韩| 初美沙希中文字幕在线| 亚洲精品一区二区三区老狼| 欧美黄色录像免费看的| 成人亚洲国产综合精品| 黑人变态深video特大巨大| 精品国产乱码一区二区三区乱| 不卡一不卡二不卡三| av无限看熟女人妻另类av| sw137 中文字幕 在线| 久久这里只有精品热视频| 亚洲精品精品国产综合| 爱爱免费在线观看视频| 内射久久久久综合网| 一区二区三区另类在线| 亚洲图片偷拍自拍区| 久久久超爽一二三av| 第一福利视频在线观看| 免费啪啪啪在线观看视频| 欧美成人综合视频一区二区 | 五色婷婷综合狠狠爱| 狠狠躁狠狠爱网站视频| 二区中出在线观看老师| 欧美偷拍亚洲一区二区| 成年人黄视频在线观看| 五十路老熟女码av| 99re国产在线精品| 亚洲欧美人精品高清| 成人av久久精品一区二区| 少妇系列一区二区三区视频| 午夜国产福利在线观看| 欧美精品一二三视频| 在线免费观看日本伦理| 少妇与子乱在线观看| 亚洲综合另类精品小说| 成人色综合中文字幕| 美女 午夜 在线视频| 亚洲av日韩av第一区二区三区| 日韩欧美一级aa大片| 青青尤物在线观看视频网站 | 国产使劲操在线播放| 鸡巴操逼一级黄色气| 大香蕉大香蕉在线有码 av| 日韩精品中文字幕在线| 人妻丝袜榨强中文字幕| 免费看国产又粗又猛又爽又黄视频| 久青青草视频手机在线免费观看 | 天天草天天色天天干| 中文字幕免费福利视频6| 在线观看视频网站麻豆| 骚逼被大屌狂草视频免费看| 男人靠女人的逼视频| 国产丰满熟女成人视频| 粉嫩欧美美人妻小视频| 在线亚洲天堂色播av电影| 欧美va亚洲va天堂va| 夫妻在线观看视频91| 日本黄在免费看视频| av一区二区三区人妻| 99久久久无码国产精品性出奶水 | 亚洲熟女综合色一区二区三区四区| 国产黄色片蝌蚪九色91| 成人伊人精品色xxxx视频| 欧美一区二区三区在线资源| 国产精品亚洲а∨天堂免| 好男人视频在线免费观看网站| 国产V亚洲V天堂无码欠欠| 亚洲欧美在线视频第一页| 亚洲国产第一页在线观看| 人人妻人人澡人人爽人人dvl| www天堂在线久久| 日噜噜噜夜夜噜噜噜天天噜噜噜| huangse网站在线观看| 午夜在线一区二区免费| 日本人妻精品久久久久久| 大尺度激情四射网站| 99热久久极品热亚洲| 欧美精品国产综合久久| 成人av在线资源网站| 在线亚洲天堂色播av电影| 久久久久久久久久久久久97| 黄色av网站免费在线| 夜鲁夜鲁狠鲁天天在线| 少妇被强干到高潮视频在线观看| 顶级尤物粉嫩小尤物网站| 国产精品午夜国产小视频| 欧美黑人性暴力猛交喷水| av完全免费在线观看av| 福利午夜视频在线合集| 操操网操操伊剧情片中文字幕网| 亚洲av日韩av第一区二区三区| 美日韩在线视频免费看| 欧美色呦呦最新网址| 成人国产影院在线观看| 亚洲福利精品视频在线免费观看| 99人妻视频免费在线| 全国亚洲男人的天堂| 北条麻妃肉色丝袜视频| 精品黑人一区二区三区久久国产| 自拍偷区二区三区麻豆| 日本xx片在线观看| 91she九色精品国产| 97国产在线观看高清| 久久h视频在线观看| 青青青国产片免费观看视频| 91欧美在线免费观看| 综合激情网激情五月五月婷婷| 美女av色播在线播放| 欧美偷拍自拍色图片| 夫妻在线观看视频91| 制服丝袜在线人妻中文字幕| 18禁精品网站久久| jul—619中文字幕在线| 丰满的子国产在线观看| 婷婷综合蜜桃av在线| 午夜频道成人在线91| 一区二区三区视频,福利一区二区| 沙月文乃人妻侵犯中文字幕在线 | 视频一区 二区 三区 综合| 日韩精品一区二区三区在线播放| 欧美久久一区二区伊人| 中文字幕,亚洲人妻| 一级A一级a爰片免费免会员| 粉嫩欧美美人妻小视频| 五十路熟女av天堂| 一级黄色片夫妻性生活| 国产高清在线观看1区2区| 视频 国产 精品 熟女 | 亚洲免费福利一区二区三区| 亚洲中文字幕乱码区| 亚洲免费视频欧洲免费视频| 97超碰免费在线视频| 伊人日日日草夜夜草| 91精品视频在线观看免费| 国产精品入口麻豆啊啊啊| 熟女少妇激情五十路| 57pao国产一区二区| 男生用鸡操女生视频动漫| 国产熟妇乱妇熟色T区| 色婷婷综合激情五月免费观看| 97小视频人妻一区二区| 免费黄高清无码国产| 亚洲精品 日韩电影| 日本www中文字幕| 一区二区视频在线观看免费观看| 天堂av狠狠操蜜桃| 一区二区三区日本伦理| 亚洲国产欧美一区二区三区久久| 久久一区二区三区人妻欧美| 青青青青青手机视频| 日本韩国亚洲综合日韩欧美国产| 日美女屁股黄邑视频| 国产久久久精品毛片| 超碰公开大香蕉97| 国产精品三级三级三级| 成年女人免费播放视频| 午夜免费观看精品视频| 91精品国产麻豆国产| 欧美国产亚洲中英文字幕| 欧美一区二区三区乱码在线播放 | 亚洲图库另类图片区| 人妻另类专区欧美制服| 日美女屁股黄邑视频| 日韩三级电影华丽的外出| 美女大bxxxx内射| 欧美精品 日韩国产| 天天想要天天操天天干| 免费黄页网站4188| 国产va在线观看精品| 日本中文字幕一二区视频| 91九色porny国产在线| 中文字幕午夜免费福利视频| 红杏久久av人妻一区| 日韩精品中文字幕在线| 四虎永久在线精品免费区二区| 直接能看的国产av| 亚洲精品在线资源站| 日韩北条麻妃一区在线| 国产日本欧美亚洲精品视| 国产欧美精品一区二区高清 | 亚洲欧美综合另类13p| 亚洲av日韩av第一区二区三区| 51国产成人精品视频| 99热这里只有精品中文| 婷婷色中文亚洲网68| 自拍偷拍日韩欧美一区二区| 高潮喷水在线视频观看| mm131美女午夜爽爽爽| 精品一区二区三区在线观看| 日韩精品二区一区久久| 亚洲午夜电影在线观看| 爱有来生高清在线中文字幕| 中文亚洲欧美日韩无线码| 国产变态另类在线观看| 1区2区3区4区视频在线观看| 亚洲中文字幕国产日韩| 福利一二三在线视频观看| 久草视频在线看免费| 日韩美女福利视频网| 91香蕉成人app下载| 色呦呦视频在线观看视频| 亚洲 色图 偷拍 欧美| 欧美日韩亚洲国产无线码| 99热这里只有精品中文| 天堂av在线最新版在线| 欧美少妇性一区二区三区| 99热色原网这里只有精品| 久久久久久99国产精品| 黄色中文字幕在线播放| 一级a看免费观看网站| 日韩不卡中文在线视频网站| 天天日天天干天天插舔舔| 国产大学生援交正在播放| 亚洲国产40页第21页| 精品国产乱码一区二区三区乱| 97年大学生大白天操逼| 亚洲视频乱码在线观看| 久久丁香婷婷六月天| 97人妻无码AV碰碰视频| 国产亚洲视频在线观看| 美女骚逼日出水来了| 亚洲成人精品女人久久久| 国产熟妇一区二区三区av| 1024久久国产精品| 2020久久躁狠狠躁夜夜躁| 欧美亚洲一二三区蜜臀| 国产日韩精品电影7777| 天天射夜夜操狠狠干| 一区二区视频视频视频| 亚洲一级特黄特黄黄色录像片| 亚洲图库另类图片区| caoporm超碰国产| 午夜福利人人妻人人澡人人爽| 久久尻中国美女视频| 国产成人小视频在线观看无遮挡| 黄色视频成年人免费观看| 边摸边做超爽毛片18禁色戒 | 在线观看av亚洲情色| 在线免费91激情四射| 国产麻豆剧果冻传媒app| 91精品国产综合久久久蜜| 国产三级精品三级在线不卡| 中文字幕日韩人妻在线三区| 免费在线看的黄片视频| 亚洲少妇人妻无码精品| 绝顶痉挛大潮喷高潮无码| 日韩成人性色生活片| 欧美一级视频一区二区| 色爱av一区二区三区| 青青社区2国产视频| 中文字幕亚洲中文字幕| 视频一区二区综合精品| www日韩毛片av| 欧美久久久久久三级网| okirakuhuhu在线观看| 国产白袜脚足J棉袜在线观看| 精品高潮呻吟久久av| 日韩美女搞黄视频免费| 亚洲欧美综合另类13p| 中文字幕日韩人妻在线三区| aaa久久久久久久久| 98精产国品一二三产区区别| 成人18禁网站在线播放| 国产精品国产精品一区二区| 日本一二三中文字幕| 少妇高潮一区二区三区| 大肉大捧一进一出好爽在线视频| 午夜频道成人在线91| 欧亚日韩一区二区三区观看视频| 黄片三级三级三级在线观看| 91中文字幕免费在线观看| 男人和女人激情视频| 色哟哟国产精品入口| 亚洲综合另类欧美久久| 国产变态另类在线观看| 成人国产影院在线观看| 中文字幕在线观看国产片| 亚洲一区二区三区久久午夜| 亚洲最大黄 嗯色 操 啊| 中文 成人 在线 视频| 亚洲综合另类欧美久久| 日本阿v视频在线免费观看| 日辽宁老肥女在线观看视频| 亚洲av无乱一区二区三区性色| 欧美精品激情在线最新观看视频| nagger可以指黑人吗| 国产成人自拍视频播放| av天堂中文免费在线| 亚洲国产美女一区二区三区软件| 成人av久久精品一区二区| 欧美伊人久久大香线蕉综合| 亚洲码av无色中文| 亚洲的电影一区二区三区| 2021天天色天天干| 日韩在线中文字幕色| 69精品视频一区二区在线观看| 亚洲欧美精品综合图片小说| 亚洲av成人网在线观看| 91精品一区二区三区站长推荐| 中文字幕人妻被公上司喝醉在线| 亚洲精品av在线观看| 四川乱子伦视频国产vip| 偷拍3456eee| 天堂v男人视频在线观看| 亚洲人妻国产精品综合| 9色在线视频免费观看| 2022精品久久久久久中文字幕| 国产精品大陆在线2019不卡| 免费无码人妻日韩精品一区二区| 在线观看亚洲人成免费网址| 做爰视频毛片下载蜜桃视频1| 在线网站你懂得老司机| 免费在线观看污污视频网站| 在线观看免费av网址大全| 成人国产小视频在线观看| 国产精品3p和黑人大战| 欧美精品欧美极品欧美视频| 久草视频在线免播放| 亚洲 图片 欧美 图片| 2025年人妻中文字幕乱码在线| 精品成人啪啪18免费蜜臀| 日韩欧美亚洲熟女人妻| 亚洲成人国产av在线| 最后99天全集在线观看| 国产va精品免费观看 | 日本av熟女在线视频| 99精品免费久久久久久久久a| 日韩欧美国产一区不卡| 天天干天天日天天干天天操| 男人的天堂在线黄色| ka0ri在线视频| 色秀欧美视频第一页| 青青青青青手机视频| 黄色片年轻人在线观看| caoporm超碰国产| 午夜久久久久久久精品熟女| 精品美女福利在线观看| 伊人成人综合开心网| 日韩精品电影亚洲一区| 在线不卡日韩视频播放| 色综合久久五月色婷婷综合| 天天日天天操天天摸天天舔| 老司机99精品视频在线观看| 欧美精产国品一二三产品价格| 亚洲 欧美 自拍 偷拍 在线| 内射久久久久综合网| 中文字幕AV在线免费看 | 福利国产视频在线观看| 91大屁股国产一区二区| 国产片免费观看在线观看| 欧美日韩人妻久久精品高清国产| 99人妻视频免费在线| 亚洲一区久久免费视频| 国产精品久久久久网| 国产极品精品免费视频| 免费在线看的黄片视频| 天天干夜夜操啊啊啊| 国产在线观看黄色视频| 欧美日韩情色在线观看| 端庄人妻堕落挣扎沉沦| 人妻凌辱欧美丰满熟妇| 2018最新中文字幕在线观看| 日本韩国亚洲综合日韩欧美国产| 国产实拍勾搭女技师av在线| 噜噜色噜噜噜久色超碰| 绝顶痉挛大潮喷高潮无码| 男女之间激情网午夜在线| 人妻激情图片视频小说| 91亚洲手机在线视频播放| 老鸭窝日韩精品视频观看| 在线观看视频一区麻豆| 天堂中文字幕翔田av| 国产九色91在线视频| 亚洲精品午夜aaa久久| 2020久久躁狠狠躁夜夜躁| 日本中文字幕一二区视频| 一区二区视频在线观看免费观看| 最新日韩av传媒在线| 熟女在线视频一区二区三区| 在线免费观看欧美小视频| a v欧美一区=区三区| 国产又色又刺激在线视频| 中文字幕第1页av一天堂网 | 大陆精品一区二区三区久久| 水蜜桃一区二区三区在线观看视频| 密臀av一区在线观看| 337p日本大胆欧美人| v888av在线观看视频| 久久精品视频一区二区三区四区| 欧美熟妇一区二区三区仙踪林| 在线观看黄色成年人网站| 999热精品视频在线| 亚洲av男人天堂久久| 日本黄在免费看视频| 久久久久久久99精品| 亚洲一区二区三区久久午夜| 91av精品视频在线| 一色桃子久久精品亚洲 | 国产一区成人在线观看视频| 黑人变态深video特大巨大| 日本a级视频老女人| 天天操天天干天天日狠狠插 | 综合页自拍视频在线播放| 日本真人性生活视频免费看| 蜜桃视频入口久久久| 在线观看视频一区麻豆| 国产V亚洲V天堂无码欠欠| 岛国一区二区三区视频在线| 岛国免费大片在线观看| 影音先锋女人av噜噜色| 亚洲欧美日韩视频免费观看| 天天射夜夜操综合网| 99久久中文字幕一本人| 国产精品成久久久久三级蜜臀av| 激情综合治理六月婷婷| 亚洲成人av在线一区二区| 亚洲日本一区二区久久久精品| 免费69视频在线看| 日韩av有码一区二区三区4| 黄网十四区丁香社区激情五月天| 欧美视频不卡一区四区| 国产卡一卡二卡三乱码手机| 国产精品女邻居小骚货| 欧美专区第八页一区在线播放| 偷拍自拍福利视频在线观看| huangse网站在线观看| 日日操夜夜撸天天干| 欧美精品黑人性xxxx| 亚洲1069综合男同| 视频 国产 精品 熟女 | 天天射,天天操,天天说| 欧美黑人与人妻精品| 国产午夜亚洲精品不卡在线观看| 九九热99视频在线观看97| 亚洲综合自拍视频一区| 亚洲一区二区三区uij| 日韩欧美国产精品91| 女同互舔一区二区三区| 91天堂精品一区二区| 国产美女精品福利在线| 美女日逼视频免费观看| 国产午夜无码福利在线看| 亚洲精品欧美日韩在线播放 | 亚洲区欧美区另类最新章节| av中文在线天堂精品| 漂亮 人妻被中出中文| 天天躁日日躁狠狠躁av麻豆| 后入美女人妻高清在线| 国产一区二区视频观看| 国际av大片在线免费观看| 岛国青草视频在线观看| av天堂加勒比在线| 欧洲精品第一页欧洲精品亚洲 | 国产精品大陆在线2019不卡| 日韩精品电影亚洲一区| 一区国内二区日韩三区欧美| 91chinese在线视频| av在线资源中文字幕| 91超碰青青中文字幕| 精品久久久久久久久久久久人妻 | 午夜青青草原网在线观看| 国产精品人妻66p| 大香蕉伊人中文字幕| 97少妇精品在线观看| 亚洲伊人久久精品影院一美女洗澡| 成年午夜影片国产片| 亚洲推理片免费看网站| 亚洲国产成人无码麻豆艾秋| 91chinese在线视频| 一区二区久久成人网| 亚洲成人激情视频免费观看了| 亚洲综合乱码一区二区| 欧美一区二区三区在线资源| 爆乳骚货内射骚货内射在线| 91久久人澡人人添人人爽乱| 亚洲超碰97人人做人人爱| 日韩写真福利视频在线观看| 亚洲国产香蕉视频在线播放| 成年午夜免费无码区| 国产成人精品午夜福利训2021| 在线观看免费视频网| 精品老妇女久久9g国产| 午夜精品一区二区三区城中村| 婷婷综合亚洲爱久久| 精品人人人妻人人玩日产欧| 爱有来生高清在线中文字幕| av久久精品北条麻妃av观看| 一区二区三区四区视频在线播放| 5528327男人天堂| 天堂av中文在线最新版| 色伦色伦777国产精品| 把腿张开让我插进去视频| 色综合久久久久久久久中文| 中国黄色av一级片| 亚洲国产欧美一区二区三区久久| 国产一级麻豆精品免费| 大鸡八强奸视频在线观看| 黄片色呦呦视频免费看| 美味人妻2在线播放| 视频二区在线视频观看| lutube在线成人免费看| 韩国亚洲欧美超一级在线播放视频| 国产黄网站在线观看播放| 亚洲成人免费看电影| 亚洲成人av一区在线| 高清成人av一区三区| 最新中文字幕乱码在线| 欧美一区二区三区四区性视频| 中文字幕在线乱码一区二区| 18禁美女无遮挡免费| 偷拍自拍亚洲美腿丝袜| 91人妻精品久久久久久久网站| 在线免费观看99视频| 国产av欧美精品高潮网站| 视频一区二区在线免费播放| 2025年人妻中文字幕乱码在线| 黑人大几巴狂插日本少妇| 看一级特黄a大片日本片黑人| 首之国产AV医生和护士小芳| 福利在线视频网址导航| 日韩亚洲高清在线观看| 一区二区熟女人妻视频| 日本性感美女三级视频| 51国产成人精品视频| 亚洲一级 片内射视正片| 经典国语激情内射视频| 国产一线二线三线的区别在哪| 亚洲欧美综合另类13p| 被大鸡吧操的好舒服视频免费| 老鸭窝日韩精品视频观看| 任你操任你干精品在线视频| 亚洲一级 片内射视正片| 天天做天天干天天操天天射| 亚洲人妻30pwc| 在线观看一区二区三级| 国产一级精品综合av| 视频一区 视频二区 视频| 男人操女人的逼免费视频| 91国产在线视频免费观看| 亚洲精品精品国产综合| 激情国产小视频在线| 亚洲自拍偷拍综合色| 中文字幕高清在线免费播放 | 欧美国产亚洲中英文字幕| 91色九色porny| 亚洲欧美精品综合图片小说| 欧美xxx成人在线| 在线观看免费视频色97| 欧美视频综合第一页| 欧美一区二区三区啪啪同性| 啊啊好大好爽啊啊操我啊啊视频| 自拍偷拍,中文字幕| 91精品综合久久久久3d动漫| 熟女视频一区,二区,三区| 精品久久久久久高潮| 色综合色综合色综合色| 天天做天天干天天操天天射| 亚洲欧美一区二区三区爱爱动图| 黑人3p华裔熟女普通话| 亚洲av一妻不如妾| 在线观看免费视频网| 成人av电影免费版| 国产乱子伦一二三区| 91试看福利一分钟| 伊拉克及约旦宣布关闭领空| 五十路丰满人妻熟妇| jul—619中文字幕在线| 日本美女成人在线视频| 无码中文字幕波多野不卡| 国产亚洲视频在线二区| 免费观看污视频网站| 91啪国自产中文字幕在线| 激情啪啪啪啪一区二区三区| 国产午夜激情福利小视频在线| 制丝袜业一区二区三区| 亚洲2021av天堂| 久久热久久视频在线观看| 欧美一区二区三区高清不卡tv| 男人的网址你懂的亚洲欧洲av| 中国无遮挡白丝袜二区精品| 国产精品欧美日韩区二区| 天天操夜夜操天天操天天操| 操的小逼流水的文章| 999热精品视频在线| 亚洲人妻视频在线网| 成人性爱在线看四区| 97人妻色免费视频| 少妇被强干到高潮视频在线观看 | 狠狠鲁狠狠操天天晚上干干| 成人H精品动漫在线无码播放| gogo国模私拍视频| 成人18禁网站在线播放| 国产+亚洲+欧美+另类| 非洲黑人一级特黄片| 男女啪啪啪啪啪的网站| 亚洲天堂精品久久久| 亚洲无线观看国产高清在线| 亚洲熟女女同志女同| 青青草人人妻人人妻| 伊人精品福利综合导航| 国产女人被做到高潮免费视频| 成人网18免费视频版国产| 天天日天天舔天天射进去| 91试看福利一分钟| 91色老99久久九九爱精品| 99久久99一区二区三区| 日本xx片在线观看| 国产av国片精品一区二区| 在线 中文字幕 一区| 亚洲第一黄色在线观看| 国产精品精品精品999| 一区国内二区日韩三区欧美| 大黑人性xxxxbbbb| 亚洲av色图18p| 亚洲女人的天堂av| 2018最新中文字幕在线观看| 午夜精品福利91av| 大陆胖女人与丈夫操b国语高清| 18禁污污污app下载| 九九视频在线精品播放| 女同久久精品秋霞网| 天天操天天操天天碰| 国产伊人免费在线播放| 一区二区三区日本伦理| 天天操夜夜骑日日摸| 天天色天天操天天舔| 成人18禁网站在线播放| 91‖亚洲‖国产熟女| 亚洲天堂av最新网址| 亚洲黄色av网站免费播放| 日韩精品激情在线观看| 97国产在线av精品| 一区二区三区日韩久久| 午夜福利人人妻人人澡人人爽 | 男人的天堂在线黄色| 日韩人妻xxxxx| 青青青青青青青青青青草青青 | 嫩草aⅴ一区二区三区| 亚洲国产成人无码麻豆艾秋| 色噜噜噜噜18禁止观看| 亚洲av成人免费网站| 日本性感美女三级视频| 亚洲国产美女一区二区三区软件| 亚洲av成人免费网站| 性色蜜臀av一区二区三区| 三级av中文字幕在线观看| 色秀欧美视频第一页| 亚洲中文精品字幕在线观看| 美女吃鸡巴操逼高潮视频| 人妻自拍视频中国大陆| www日韩毛片av| 中文字母永久播放1区2区3区| 天天干夜夜操啊啊啊| 久久久91蜜桃精品ad| japanese五十路熟女熟妇| 五十路在线观看完整版| 男人和女人激情视频| 日本三极片中文字幕| 日本一道二三区视频久久| 亚洲另类伦春色综合小| 亚洲欧美激情国产综合久久久| 国产刺激激情美女网站| 午夜成午夜成年片在线观看| 国产精品黄色的av| 久久久久久久久久性潮| 日韩a级黄色小视频| 久久午夜夜伦痒痒想咳嗽P| 日韩欧美在线观看不卡一区二区| 久久丁香花五月天色婷婷| 欧美一区二区三区四区性视频| jiujiure精品视频在线| 后入美女人妻高清在线| 视频在线免费观看你懂得| 丰满的子国产在线观看| 国产成人午夜精品福利| 国产美女午夜福利久久| 欧美成人一二三在线网| 亚洲日本一区二区三区| 中国黄色av一级片| 换爱交换乱高清大片| 青青草成人福利电影| 9l人妻人人爽人人爽| 日韩av免费观看一区| 91久久综合男人天堂| 天天操天天污天天射| 97瑟瑟超碰在线香蕉| 天天操夜夜操天天操天天操| 岛国一区二区三区视频在线| 日韩av大胆在线观看| 在线免费观看靠比视频的网站| 亚洲粉嫩av一区二区三区| 无码国产精品一区二区高潮久久4| 男女啪啪啪啪啪的网站| 99热这里只有国产精品6| 亚洲欧美国产综合777| 国产麻豆91在线视频| japanese日本熟妇另类| 久久久91蜜桃精品ad| 亚洲男人在线天堂网| 亚洲精品 欧美日韩| 国产欧美精品免费观看视频| 亚洲国产最大av综合| 亚洲av香蕉一区区二区三区犇 | 欧美精品国产综合久久| 亚洲日本一区二区三区| 亚洲精品三级av在线免费观看| 91精品国产观看免费| 色综合久久久久久久久中文| 青娱乐最新视频在线| 欧美少妇性一区二区三区| 一区二区三区综合视频| 人妻丝袜精品中文字幕| 高清一区二区欧美系列| 人人妻人人爽人人澡人人精品| 黄色成年网站午夜在线观看| 五色婷婷综合狠狠爱| 美女吃鸡巴操逼高潮视频| 天天干天天操天天爽天天摸| 国产内射中出在线观看| 亚洲熟妇无码一区二区三区| 亚洲欧美激情国产综合久久久| 欧美激情精品在线观看| 欧美久久一区二区伊人| 青青草精品在线视频观看| 国产精品欧美日韩区二区| 久久久久久久久久久免费女人| 75国产综合在线视频| 日韩欧美高清免费在线| 亚洲精品亚洲人成在线导航| 日本一本午夜在线播放| 精品一区二区三区三区色爱| 日韩精品啪啪视频一道免费| 2021天天色天天干| 国产视频在线视频播放| 久久这里有免费精品| 日本少妇人妻xxxxx18| 黄色在线观看免费观看在线| 2022中文字幕在线| tube69日本少妇| 内射久久久久综合网| 精品高潮呻吟久久av| 香蕉aⅴ一区二区三区| 天天色天天操天天舔| 成人蜜桃美臀九一一区二区三区| 18禁精品网站久久| 天天摸天天干天天操科普| 4个黑人操素人视频网站精品91| 国产九色91在线视频| 中文字幕视频一区二区在线观看 | 国产va精品免费观看| 国产熟妇人妻ⅹxxxx麻豆| 老司机福利精品免费视频一区二区 | 人妻无码色噜噜狠狠狠狠色| 亚洲精品在线资源站| 精品91高清在线观看| 久久久久久cao我的性感人妻| 日韩欧美中文国产在线| 欧美色呦呦最新网址| 亚洲精品一线二线在线观看| 久草电影免费在线观看| 日辽宁老肥女在线观看视频| 最新国产精品网址在线观看| 欧美精品 日韩国产| 亚洲高清国产自产av| 亚洲欧美福利在线观看| 亚洲一级 片内射视正片| 肏插流水妹子在线乐播下载| 18禁免费av网站| 欧美另类一区二区视频| 无套猛戳丰满少妇人妻| 色吉吉影音天天干天天操| 姐姐的朋友2在线观看中文字幕| 亚洲欧美综合在线探花| 黑人性生活视频免费看| 欧美亚洲一二三区蜜臀| 黑人性生活视频免费看| 91成人在线观看免费视频| 亚洲中文字字幕乱码| 99国内小视频在现欢看| 神马午夜在线观看视频| 97人妻人人澡爽人人精品| 亚洲 人妻 激情 中文| 白嫩白嫩美女极品国产在线观看| 色天天天天射天天舔| 国产视频网站一区二区三区 | 在线免费观看99视频| 久久精品在线观看一区二区| 91九色porny蝌蚪国产成人| 91一区精品在线观看| 日韩欧美亚洲熟女人妻| 亚洲欧美综合另类13p| 亚洲欧美清纯唯美另类| 青青草人人妻人人妻| 亚洲欧美久久久久久久久| 国产日韩av一区二区在线| 亚洲中文字幕校园春色| 久久久极品久久蜜桃| 97国产精品97久久| 日韩剧情片电影在线收看| 在线观看的黄色免费网站| 青青草人人妻人人妻| 亚洲av天堂在线播放| 91九色porny国产蝌蚪视频| 亚洲av日韩精品久久久| 中出中文字幕在线观看 | 亚洲1卡2卡三卡4卡在线观看 | 大香蕉日本伊人中文在线| 久久美欧人妻少妇一区二区三区| 成人性爱在线看四区| 美女日逼视频免费观看| 日本a级视频老女人| 边摸边做超爽毛片18禁色戒| 亚洲日产av一区二区在线| 国产在线拍揄自揄视频网站| 色综合久久久久久久久中文| 亚洲美女高潮喷浆视频| 色综合久久无码中文字幕波多| 欧美一区二区三区久久久aaa| 农村胖女人操逼视频| 一区二区三区美女毛片| 中文字幕人妻av在线观看| 青娱乐在线免费视频盛宴| 成人综合亚洲欧美一区 | 国产夫妻视频在线观看免费| xxx日本hd高清| 黄色黄色黄片78在线| 免费人成黄页网站在线观看国产| 亚洲推理片免费看网站| 亚洲人妻30pwc| aⅴ精产国品一二三产品| 欧美爆乳肉感大码在线观看| av手机在线免费观看日韩av| 亚洲国产成人在线一区| 中文字幕亚洲中文字幕| 激情五月婷婷免费视频| 福利视频网久久91| 激情啪啪啪啪一区二区三区| 999久久久久999| 中文字幕在线免费第一页| 自拍偷拍,中文字幕| 国产精品大陆在线2019不卡| 丰满熟女午夜福利视频| 一区二区三区视频,福利一区二区| 亚洲一区二区三区在线高清| 午夜毛片不卡在线看| 五十路av熟女松本翔子| 国产高清女主播在线| 天天操,天天干,天天射| 国产91久久精品一区二区字幕| 亚洲av成人网在线观看| 蜜臀av久久久久蜜臀av麻豆| 国产超码片内射在线| 在线新三级黄伊人网| 四虎永久在线精品免费区二区| 欧美日韩亚洲国产无线码| av日韩在线免费播放| 亚洲伊人色一综合网| 日本xx片在线观看| 五月精品丁香久久久久福利社| 最新97国产在线视频| 成人av中文字幕一区| 欧美一区二区中文字幕电影| 视频在线亚洲一区二区| 免费69视频在线看| 亚洲视频在线观看高清| 偷拍自拍 中文字幕| 91天堂精品一区二区| 国产一区自拍黄视频免费观看| 91亚洲国产成人精品性色| 人妻熟女在线一区二区| 成人av久久精品一区二区| 免费无码人妻日韩精品一区二区| 老司机在线精品福利视频| 亚洲av日韩精品久久久久久hd| 欧美韩国日本国产亚洲| 精品高跟鞋丝袜一区二区| 日本a级视频老女人| huangse网站在线观看| 在线观看一区二区三级| 亚洲一级 片内射视正片| 骚逼被大屌狂草视频免费看| 91九色国产porny蝌蚪| 51国产成人精品视频| 亚洲天堂av最新网址| 欧美视频不卡一区四区| 国产亚洲精品欧洲在线观看| 人妻久久久精品69系列| 国产刺激激情美女网站| 早川濑里奈av黑人番号| 男人操女人的逼免费视频| 免费黄色成人午夜在线网站| 人妻自拍视频中国大陆| 91欧美在线免费观看| 欧美久久一区二区伊人| 国产精品入口麻豆啊啊啊| 国产黄色片在线收看| 亚洲欧美福利在线观看| 五十路人妻熟女av一区二区 | 国产福利小视频免费观看| 亚洲图片偷拍自拍区| 亚洲第一黄色在线观看| 热99re69精品8在线播放| 少妇系列一区二区三区视频| 亚洲精品无码色午夜福利理论片| 66久久久久久久久久久| 黄色成年网站午夜在线观看| 欧美亚洲自偷自拍 在线| 老司机免费视频网站在线看| 国产一区二区三免费视频| 色在线观看视频免费的| 红桃av成人在线观看| 一区二区在线视频中文字幕| 日本人妻欲求不满中文字幕| 欧美日韩在线精品一区二区三| 亚洲在线免费h观看网站| 一区二区三区国产精选在线播放| 久草视频首页在线观看| 97年大学生大白天操逼| 伊人情人综合成人久久网小说 | 国产精品人妻熟女毛片av久| 97青青青手机在线视频| 欧美熟妇一区二区三区仙踪林| 91大屁股国产一区二区| 亚洲偷自拍高清视频| 岛国一区二区三区视频在线| 中文字幕人妻av在线观看| 久久久久只精品国产三级| 日本熟妇一区二区x x| 不卡精品视频在线观看| 2021国产一区二区| 日韩成人性色生活片| av日韩在线免费播放| 欧美女同性恋免费a| 青青在线视频性感少妇和隔壁黑丝| 日韩欧美亚洲熟女人妻| 欧美天堂av无线av欧美| 成人福利视频免费在线| 日日夜夜狠狠干视频| 亚洲一级美女啪啪啪| 内射久久久久综合网| 99热久久极品热亚洲| 亚洲一级美女啪啪啪| 激情国产小视频在线| 精品老妇女久久9g国产| 淫秽激情视频免费观看| 熟女人妻在线中出观看完整版| 91传媒一区二区三区| 精品av国产一区二区三区四区 | 91精品国产高清自在线看香蕉网 | 精品91高清在线观看| 久久久精品999精品日本| 日韩三级黄色片网站| 2020中文字幕在线播放| 国产视频网站国产视频| 青青色国产视频在线| 家庭女教师中文字幕在线播放| 日韩伦理短片在线观看| 青青在线视频性感少妇和隔壁黑丝 | 大鸡吧插入女阴道黄色片| 亚洲免费av在线视频| 亚洲丝袜老师诱惑在线观看| 五十路老熟女码av| 91老师蜜桃臀大屁股| 日日摸夜夜添夜夜添毛片性色av| 欧美va不卡视频在线观看| 5528327男人天堂| 青青青青青青草国产| 国产精品精品精品999| 欧美日韩国产一区二区三区三州 | 国产janese在线播放| 老鸭窝日韩精品视频观看| 青青青青青免费视频| 插逼视频双插洞国产操逼插洞| 91chinese在线视频| 亚洲乱码中文字幕在线| 成人亚洲精品国产精品| 免费在线观看视频啪啪| 特黄老太婆aa毛毛片| 操日韩美女视频在线免费看 | 亚洲高清视频在线不卡| 一区二区三区欧美日韩高清播放| 80电影天堂网官网| 亚洲午夜福利中文乱码字幕| 青青色国产视频在线| 美味人妻2在线播放| 天天日天天日天天射天天干| 亚洲av日韩高清hd| 国产精品人妻熟女毛片av久| 沈阳熟妇28厘米大战黑人| 日本av在线一区二区三区| 久久久久久cao我的性感人妻 | 国产又粗又猛又爽又黄的视频在线| 熟女国产一区亚洲中文字幕| 18禁美女无遮挡免费| 大香蕉福利在线观看| 亚洲欧洲一区二区在线观看| 免费无毒热热热热热热久| 91亚洲手机在线视频播放| 91九色porny国产蝌蚪视频| 91人妻人人做人人爽在线| 免费69视频在线看| 久久农村老妇乱69系列| 91国内精品久久久久精品一| 直接观看免费黄网站| avjpm亚洲伊人久久| 国产精品国产三级国产午| 在线观看av亚洲情色| 久久久久只精品国产三级| 唐人色亚洲av嫩草| 最新97国产在线视频| okirakuhuhu在线观看| 99久久99久国产黄毛片| 美女日逼视频免费观看| 亚洲va欧美va人人爽3p| 国产普通话插插视频| 国产精品自拍在线视频| 75国产综合在线视频| 欧美成人综合视频一区二区| 国产麻豆剧传媒精品国产av蜜桃| 一区二区三区国产精选在线播放| 亚洲成av人无码不卡影片一| 日本人妻少妇18—xx| 99久久激情婷婷综合五月天| 久久精品亚洲成在人线a| 97超碰免费在线视频| 97小视频人妻一区二区| 美日韩在线视频免费看| 亚洲精品福利网站图片| 婷婷色国产黑丝少妇勾搭AV| 国产a级毛久久久久精品| 午夜在线一区二区免费| 国产大学生援交正在播放| 人妻无码色噜噜狠狠狠狠色| 中文字幕在线视频一区二区三区| 538精品在线观看视频| 久久人人做人人妻人人玩精品vr| 插小穴高清无码中文字幕| 中文字幕,亚洲人妻| 红杏久久av人妻一区| 成人H精品动漫在线无码播放| 操日韩美女视频在线免费看| 一区二区三区 自拍偷拍| 日本av熟女在线视频| 久久午夜夜伦痒痒想咳嗽P| 蜜臀av久久久久久久| 亚洲熟色妇av日韩熟色妇在线 | 中文字幕日韩精品日本| 91久久综合男人天堂| 国产精品亚洲在线观看| 99的爱精品免费视频| 亚洲高清视频在线不卡| 91中文字幕免费在线观看| 一区二区三区久久中文字幕| av在线免费资源站| 亚洲天堂成人在线观看视频网站| av手机在线观播放网站| 男人的网址你懂的亚洲欧洲av| 午夜精品福利一区二区三区p| 硬鸡巴动态操女人逼视频| 亚洲av极品精品在线观看| 91欧美在线免费观看| 亚洲精品午夜aaa久久| 青青擦在线视频国产在线| 亚洲熟妇久久无码精品| 啪啪啪啪啪啪啪啪av| 国产亚洲四十路五十路| 午夜精品一区二区三区更新| 2020久久躁狠狠躁夜夜躁| 欧美中国日韩久久精品| 中文字幕亚洲久久久| 国产精品一区二区av国| 亚洲国产免费av一区二区三区| 欧美老妇精品另类不卡片| 中文字幕av男人天堂| 国产精品黄大片在线播放| 久久精品国产亚洲精品166m| 国产精品成久久久久三级蜜臀av| 国产三级影院在线观看| 人人妻人人澡欧美91精品| 大香蕉伊人中文字幕| 40道精品招牌菜特色| 国产精品久久综合久久| 亚洲av男人天堂久久| 精品av国产一区二区三区四区| 成人影片高清在线观看| 中文亚洲欧美日韩无线码| 国产又粗又硬又猛的毛片视频 | 日本熟妇色熟妇在线观看| 国产午夜激情福利小视频在线| 日韩人妻xxxxx| 日本精品一区二区三区在线视频。| 久草电影免费在线观看| 日韩av大胆在线观看| 偷偷玩弄新婚人妻h视频| 国产精品成久久久久三级蜜臀av| 在线可以看的视频你懂的| 欧洲精品第一页欧洲精品亚洲| av日韩在线观看大全| av中文字幕网址在线| 亚洲av香蕉一区区二区三区犇| 亚洲美女美妇久久字幕组| jiuse91九色视频| 又大又湿又爽又紧A视频| 93精品视频在线观看| 成年人黄色片免费网站| 亚洲av午夜免费观看| av高潮迭起在线观看| 午夜毛片不卡免费观看视频 | 91在线免费观看成人| 激情国产小视频在线| 国产日韩精品一二三区久久久| 国产一区自拍黄视频免费观看| yy96视频在线观看| 亚洲成人激情视频免费观看了| 久久久精品999精品日本| 亚洲精品色在线观看视频| 在线观看av观看av| 国产97在线视频观看| 男人和女人激情视频| 大香蕉玖玖一区2区| 国产成人午夜精品福利| 大肉大捧一进一出好爽在线视频| 精品亚洲国产中文自在线| 日韩精品二区一区久久| 国产日韩欧美视频在线导航| 亚洲超碰97人人做人人爱| www日韩a级s片av| 夜色撩人久久7777| 一个人免费在线观看ww视频| AV无码一区二区三区不卡| 亚洲精品高清自拍av| 人妻无码色噜噜狠狠狠狠色| av中文字幕国产在线观看| 亚洲一区二区三区精品乱码| 欧美一区二区中文字幕电影| 18禁美女无遮挡免费| 超黄超污网站在线观看| 在线国产精品一区二区三区| 亚洲一区二区三区偷拍女厕91| 欧美日韩激情啪啪啪| 亚洲视频乱码在线观看| 欧美xxx成人在线| 啊啊啊视频试看人妻| 国产精品福利小视频a| 中文字幕无码一区二区免费| 1区2区3区4区视频在线观看| 在线免费视频 自拍| 99精品久久久久久久91蜜桃| 欧美viboss性丰满| 99久久激情婷婷综合五月天| 亚洲免费va在线播放| 亚洲视频乱码在线观看| 人妻无码色噜噜狠狠狠狠色| 初美沙希中文字幕在线| 亚洲熟妇x久久av久久| 少妇人妻二三区视频| 亚洲成人av在线一区二区| 日韩美女精品视频在线观看网站| 边摸边做超爽毛片18禁色戒| 唐人色亚洲av嫩草| 婷婷综合蜜桃av在线| 一区二区三区av高清免费| rct470中文字幕在线| 男人天堂av天天操| 亚洲第一伊人天堂网| 国产一区成人在线观看视频| 天天插天天色天天日| 99人妻视频免费在线| 亚洲天天干 夜夜操| 91精品国产黑色丝袜| 国产品国产三级国产普通话三级| jiujiure精品视频在线| 亚洲国产成人av在线一区| 国产在线拍揄自揄视频网站| 黄色无码鸡吧操逼视频| 国产黑丝高跟鞋视频在线播放| 国产欧美精品一区二区高清| 自拍偷拍亚洲另类色图| 黄色的网站在线免费看| 国产伊人免费在线播放| 爱有来生高清在线中文字幕| 97少妇精品在线观看| 99热久久这里只有精品8| 国产伦精品一区二区三区竹菊| 91久久综合男人天堂| 亚洲午夜电影之麻豆| av中文字幕网址在线| 老熟妇凹凸淫老妇女av在线观看| 亚洲av香蕉一区区二区三区犇| yellow在线播放av啊啊啊| 一区二区三区麻豆福利视频| 欧美日本国产自视大全| 91片黄在线观看喷潮| 337p日本大胆欧美人| 毛片av在线免费看| 亚洲午夜福利中文乱码字幕| 久久久久久久久久性潮| 欧美日韩情色在线观看| 日本午夜福利免费视频| 91超碰青青中文字幕| 91精品一区二区三区站长推荐| 91精品一区二区三区站长推荐| 亚洲欧美日韩视频免费观看| 日韩成人性色生活片| 日本黄在免费看视频| 国产熟妇一区二区三区av| 动漫美女的小穴视频| 夜色撩人久久7777| 青娱乐蜜桃臀av色| 任你操视频免费在线观看| 国产精品视频男人的天堂| 日本黄色特一级视频| 亚洲中文字幕人妻一区| 骚货自慰被发现爆操| 国产性色生活片毛片春晓精品 | 91精品国产高清自在线看香蕉网| 日韩av有码中文字幕| 人妻少妇性色欲欧美日韩| asmr福利视频在线观看| 国产大学生援交正在播放| 色花堂在线av中文字幕九九 | 欧洲精品第一页欧洲精品亚洲| 亚洲国产在线精品国偷产拍| 肏插流水妹子在线乐播下载| 97精品成人一区二区三区| 日韩欧美一级aa大片| 亚洲欧美综合另类13p| 欧美老妇精品另类不卡片| 女生被男生插的视频网站| 国产九色91在线视频| 国产成人精品久久二区91| 女人精品内射国产99| 888亚洲欧美国产va在线播放| 人妻久久无码中文成人| 99热99re在线播放| 亚洲福利午夜久久久精品电影网| 日韩精品电影亚洲一区| 伊人精品福利综合导航| 亚洲一区二区三区精品乱码| 日本www中文字幕| 欧亚日韩一区二区三区观看视频| 韩国爱爱视频中文字幕| 国产va精品免费观看| 人人妻人人人操人人人爽| 密臀av一区在线观看| 欧美精品伦理三区四区| 日本少妇精品免费视频| 亚洲图片欧美校园春色| 人人在线视频一区二区| 天天操天天干天天日狠狠插| 蝴蝶伊人久久中文娱乐网| 特级欧美插插插插插bbbbb| 亚洲成人熟妇一区二区三区| 久久久麻豆精亚洲av麻花| 午夜精品在线视频一区| 蜜臀av久久久久蜜臀av麻豆| 2020久久躁狠狠躁夜夜躁| 97年大学生大白天操逼| 男女啪啪啪啪啪的网站| 最新日韩av传媒在线| 嫩草aⅴ一区二区三区| 伊人开心婷婷国产av| 青娱乐最新视频在线| 97超碰人人搞人人| 十八禁在线观看地址免费| 精品一区二区三区午夜| 久青青草视频手机在线免费观看| 青青青青青青青在线播放视频| 综合一区二区三区蜜臀| 亚洲成人精品女人久久久| 好男人视频在线免费观看网站| 在线成人日韩av电影| 亚洲成人激情av在线| 亚洲精品福利网站图片| 最新欧美一二三视频| 成人午夜电影在线观看 久久| 在线观看成人国产电影| av网站色偷偷婷婷网男人的天堂| 抽查舔水白紧大视频| 日本午夜久久女同精女女| 无码中文字幕波多野不卡| 福利片区一区二体验区| 久久久久久九九99精品| 大鸡吧插逼逼视频免费看| 福利在线视频网址导航| 偷拍自拍福利视频在线观看| 69精品视频一区二区在线观看| 亚洲高清国产自产av| 插逼视频双插洞国产操逼插洞 | 一区二区三区四区中文| 国产91精品拍在线观看| 91精品国产91久久自产久强| 久久精品36亚洲精品束缚| 色秀欧美视频第一页| 亚洲高清自偷揄拍自拍| 亚洲 欧美 精品 激情 偷拍| 一区二区视频视频视频| 精品久久婷婷免费视频| 亚洲男人在线天堂网| 偷拍自拍亚洲美腿丝袜| 精品美女福利在线观看| 宅男噜噜噜666免费观看| 18禁网站一区二区三区四区| 亚洲精品无码久久久久不卡| 久久久精品欧洲亚洲av| 一区二区三区四区五区性感视频| 三级等保密码要求条款| AV天堂一区二区免费试看| 日韩美女福利视频网| 男女之间激情网午夜在线| 狍和女人的王色毛片| 超碰公开大香蕉97| 免费看美女脱光衣服的视频| 午夜大尺度无码福利视频 | 亚洲av人人澡人人爽人人爱| 黄色视频在线观看高清无码| 91色秘乱一区二区三区| 亚洲熟妇x久久av久久| 亚洲成人国产av在线| 亚洲一区二区三区在线高清| 天天日天天干天天舔天天射| 超黄超污网站在线观看| 在线免费观看黄页视频| av手机在线观播放网站| 大鸡吧插逼逼视频免费看 | 啪啪啪啪啪啪啪啪av| 国产av一区2区3区| 欧美亚洲一二三区蜜臀| 成人国产激情自拍三区| 亚洲熟女综合色一区二区三区四区| 亚洲欧美激情国产综合久久久| 中文字幕日韩91人妻在线| 日日日日日日日日夜夜夜夜夜夜| 国产真实灌醉下药美女av福利| 水蜜桃一区二区三区在线观看视频 | 2018最新中文字幕在线观看| 国产精品黄片免费在线观看| 综合国产成人在线观看| 日本精品视频不卡一二三| 做爰视频毛片下载蜜桃视频1| 亚洲麻豆一区二区三区| 少妇露脸深喉口爆吞精| 大陆av手机在线观看| 中文字幕午夜免费福利视频| av俺也去在线播放| 久久综合老鸭窝色综合久久| 香港一级特黄大片在线播放| 成人激情文学网人妻| 成年人黄视频在线观看| 亚洲精品久久综合久| 男人的天堂av日韩亚洲| tube69日本少妇| 熟女人妻在线观看视频| 色吉吉影音天天干天天操| 国产福利小视频二区| sejizz在线视频| 老司机你懂得福利视频| 亚洲 中文字幕在线 日韩| 沈阳熟妇28厘米大战黑人| 欧美日韩中文字幕欧美| 天天干天天日天天干天天操| 亚洲 欧美 自拍 偷拍 在线| 中文字幕第一页国产在线| 久久久久久久亚洲午夜综合福利| 亚洲欧美另类手机在线| 快点插进来操我逼啊视频| 亚洲专区激情在线观看视频| 亚洲天堂精品久久久| 1769国产精品视频免费观看| 亚洲国产香蕉视频在线播放 | 日本熟妇一区二区x x| 伊人开心婷婷国产av| 在线视频免费观看网| 老有所依在线观看完整版| yy6080国产在线视频| av一区二区三区人妻| av久久精品北条麻妃av观看| 欧美亚洲自偷自拍 在线| 午夜久久久久久久精品熟女| jul—619中文字幕在线| 婷婷五月亚洲综合在线| 日本xx片在线观看| 欧美熟妇一区二区三区仙踪林| 亚洲欧美久久久久久久久| 亚洲另类综合一区小说| 中国黄片视频一区91| 在线播放一区二区三区Av无码| 自拍 日韩 欧美激情| 蜜桃视频在线欧美一区| 午夜婷婷在线观看视频| 亚洲国产精品久久久久蜜桃| 操的小逼流水的文章| av久久精品北条麻妃av观看| 啪啪啪啪啪啪啪啪av| 午夜精品一区二区三区福利视频| 欧美中国日韩久久精品| 中文字幕免费福利视频6| 成人在线欧美日韩国产| 懂色av之国产精品| 国产91嫩草久久成人在线视频| 国产大学生援交正在播放| 日韩欧美国产精品91| 久久www免费人成一看片| 亚洲人一区二区中文字幕| 人妻丝袜av在线播放网址| 日本韩国免费福利精品| 国产精彩对白一区二区三区| 精品一区二区三区午夜| 色婷婷综合激情五月免费观看| 护士特殊服务久久久久久久| 天堂资源网av中文字幕| 少妇露脸深喉口爆吞精| 99精品国自产在线人| 五十路熟女av天堂| 国产精品伦理片一区二区| 超黄超污网站在线观看| 国产亚洲精品视频合集| 99久久99久国产黄毛片| 久碰精品少妇中文字幕av| 扒开腿挺进肉嫩小18禁视频| 视频在线免费观看你懂得| 国产麻豆精品人妻av| 久久精品36亚洲精品束缚| 国产视频一区二区午夜| 骚逼被大屌狂草视频免费看| 亚洲精品麻豆免费在线观看| 水蜜桃一区二区三区在线观看视频 | 超鹏97历史在线观看| 东京热男人的av天堂| 亚洲欧美色一区二区| 亚洲av黄色在线网站| 天天干夜夜操啊啊啊| 人人妻人人澡人人爽人人dvl| 午夜精品福利一区二区三区p | 抽查舔水白紧大视频| 青草久久视频在线观看| 国产性感美女福利视频| av欧美网站在线观看| 成人激情文学网人妻| 成年人中文字幕在线观看| 狠狠躁狠狠爱网站视频| 中文字幕高清资源站| 18禁美女羞羞免费网站| 97精品视频在线观看| 国产精品入口麻豆啊啊啊| 色伦色伦777国产精品| 大香蕉伊人中文字幕| 91麻豆精品91久久久久同性| 大学生A级毛片免费视频| 日韩av中文在线免费观看| 黑人乱偷人妻中文字幕| 日本后入视频在线观看| 一个色综合男人天堂| 4个黑人操素人视频网站精品91| 日韩黄色片在线观看网站| 日本熟妇喷水xxx| 中文字幕,亚洲人妻| 最新91精品视频在线| 色婷婷久久久久swag精品| 亚洲av极品精品在线观看| 亚洲成人激情av在线| 国产污污污污网站在线| 国产熟妇一区二区三区av| 性感美女诱惑福利视频| 青青草亚洲国产精品视频| 被大鸡吧操的好舒服视频免费| 黑人借宿ntr人妻的沦陷2| 视频 国产 精品 熟女 | 色在线观看视频免费的| 只有精品亚洲视频在线观看| 一区二区三区精品日本| 亚洲欧美国产综合777| 内射久久久久综合网| eeuss鲁片一区二区三区| 青青青国产片免费观看视频 | 在线观看av观看av| 中文字幕日韩精品就在这里| 午夜在线观看一区视频| 最新97国产在线视频| 亚洲老熟妇日本老妇| 亚洲偷自拍高清视频| 懂色av蜜桃a v| 国产实拍勾搭女技师av在线| 一个色综合男人天堂| 天天干天天爱天天色| 欧美精品一二三视频| 一区二区三区另类在线| 日本午夜爽爽爽爽爽视频在线观看| 亚洲国产在线精品国偷产拍 | av在线免费观看亚洲天堂| 亚洲精品国产综合久久久久久久久 | av一本二本在线观看| 内射久久久久综合网| 大香蕉伊人国产在线| 在线观看欧美黄片一区二区三区| 成人av在线资源网站| 黑人性生活视频免费看| 丝袜亚洲另类欧美变态| 中国熟女@视频91| 精品久久久久久久久久久99| 国产综合视频在线看片| 四川乱子伦视频国产vip| 2021久久免费视频| 欧美亚洲偷拍自拍色图| 中国熟女@视频91| gogo国模私拍视频| 91亚洲精品干熟女蜜桃频道| 91老熟女连续高潮对白| 日韩欧美一级aa大片| 午夜毛片不卡在线看| 在线免费观看视频一二区| 97精品成人一区二区三区| 天天做天天干天天舔| 2020国产在线不卡视频| 最新黄色av网站在线观看| 日视频免费在线观看| 东京热男人的av天堂| 亚洲av第国产精品| 91老师蜜桃臀大屁股| 亚洲av自拍天堂网| 精品一线二线三线日本| 99久久超碰人妻国产| 亚洲精品精品国产综合| 影音先锋女人av噜噜色| 亚洲图片欧美校园春色| 少妇人妻久久久久视频黄片| 天天日天天操天天摸天天舔| 一区二区三区日本伦理| 91高清成人在线视频| 91国产资源在线视频| 欧美偷拍亚洲一区二区| 55夜色66夜色国产精品站| 欧美老鸡巴日小嫩逼| 国产精品国产三级麻豆| 免费黄高清无码国产| 亚洲av无码成人精品区辽| 中文 成人 在线 视频| 丝袜美腿视频诱惑亚洲无| 亚洲公开视频在线观看| 国产av欧美精品高潮网站| 福利午夜视频在线观看| 国产精品入口麻豆啊啊啊| 一色桃子人妻一区二区三区| 伊人开心婷婷国产av| 在线视频免费观看网| 九色视频在线观看免费| 丰满少妇人妻xxxxx| 中文 成人 在线 视频| 中文字幕一区二区三区蜜月| 亚洲公开视频在线观看| 4个黑人操素人视频网站精品91| 成人乱码一区二区三区av| 80电影天堂网官网| aⅴ五十路av熟女中出| 99久久久无码国产精品性出奶水| 亚洲图库另类图片区| 嫩草aⅴ一区二区三区| 亚洲一区自拍高清免费视频| 99re久久这里都是精品视频| 成人久久精品一区二区三区| 国产真实灌醉下药美女av福利| 蜜臀av久久久久久久| www天堂在线久久| 不卡一不卡二不卡三| 亚洲丝袜老师诱惑在线观看| 国产综合高清在线观看| 天天日天天日天天擦| 国产欧美日韩在线观看不卡| 中国视频一区二区三区| 欧美日韩精品永久免费网址| 美女少妇亚洲精选av| 日韩三级电影华丽的外出| 国产精彩对白一区二区三区 | 欧美亚洲牲夜夜综合久久| 国产无遮挡裸体免费直播视频 | 精品一区二区三区三区色爱| 狠狠躁狠狠爱网站视频| 久久精品美女免费视频| 宅男噜噜噜666国产| 日本高清在线不卡一区二区| 日本美女成人在线视频| 在线视频精品你懂的| 国产精品中文av在线播放 | 国产精品国产三级麻豆| 护士特殊服务久久久久久久| 伊人精品福利综合导航| 黄色成年网站午夜在线观看| 中文字幕免费福利视频6| av完全免费在线观看av| 欧美另类一区二区视频| 91综合久久亚洲综合| 成人综合亚洲欧美一区| 久久农村老妇乱69系列| 中文字幕中文字幕 亚洲国产| 在线国产日韩欧美视频| 国产精品久久久久久美女校花| 成年人午夜黄片视频资源| 免费手机黄页网址大全| 精品黑人一区二区三区久久国产| 在线新三级黄伊人网| 男人的天堂av日韩亚洲| 中文字幕人妻熟女在线电影| 日韩中文字幕精品淫| 天天躁夜夜躁日日躁a麻豆| 中文字幕在线乱码一区二区 | 天天干天天操天天扣| 欧美黑人与人妻精品|