当前位置: 首页 > news >正文

网上做造价网站做购物商城网站

网上做造价网站,做购物商城网站,最好网站开发公司电话,苏通建设集团有限公司网站处理数组array的函数已经学习完#xff0c;接下来是collection相关的函数#xff0c; collection指的是一组用于处理集合#xff08;如数组或对象#xff09;的工具函数。 lodash源码研读之forEach,forEachRight,map,flatMap,flatMapDeep,flatMapDepth 一、源码地址 GitH…处理数组array的函数已经学习完接下来是collection相关的函数 collection指的是一组用于处理集合如数组或对象的工具函数。 lodash源码研读之forEach,forEachRight,map,flatMap,flatMapDeep,flatMapDepth 一、源码地址 GitHub 地址: GitHub - lodash/lodash: A modern JavaScript utility library delivering modularity, performance, extras.官方文档地址: Lodash 官方文档 二、结构分析 forEach基于arrayEach,baseEach模块forEachRight基于arrayEachRight,baseEachRight模块,map基于arrayMapbaseMap模块flatMap,flatMapDeep,flatMapDepth基于baseFlatten模块。 三、函数介绍 下面依次介绍各个模块。 1.arrayEach模块 function arrayEach(array, iteratee) {var index -1,length array null ? 0 : array.length;while (index length) {if (iteratee(array[index], index, array) false) {break;}}return array;} arrayEach函数遍历数组中的每个元素并对每个元素执行传入的迭代函数iteratee。如果迭代函数返回 false遍历将提前终止。 2.baseEach函数 function createBaseEach(eachFunc, fromRight) {return function(collection, iteratee) {if (collection null) {return collection;}if (!isArrayLike(collection)) {return eachFunc(collection, iteratee);}var length collection.length,index fromRight ? length : -1,iterable Object(collection);while ((fromRight ? index-- : index length)) {if (iteratee(iterable[index], index, iterable) false) {break;}}return collection;};}var baseEach createBaseEach(baseForOwn);createBaseEach 函数用于生成一个新的函数 baseEach。这个新函数 baseEach 可以用来遍历集合如数组或对象并对其中的每个元素执行指定的操作。 3.forEach函数 function forEach(collection, iteratee) {var func isArray(collection) ? arrayEach : baseEach;return func(collection, getIteratee(iteratee, 3));} forEach 函数是一个更通用的函数它可以根据传入的 collection 的类型选择不同的遍历方式。如果是数组则使用 arrayEach 进行遍历否则使用 baseEach 进行遍历。这个函数的作用类似于 Loaash 中的 _.each。 4.baseEachRight模块 function arrayEachRight(array, iteratee) {var length array null ? 0 : array.length;while (length--) {if (iteratee(array[length], length, array) false) {break;}}return array;} arrayEachRight 的函数该函数用于从右到左遍历一个数组并对每个元素执行指定的操作。 5.forEachRight函数 var baseEachRight createBaseEach(baseForOwnRight, true); function forEachRight(collection, iteratee) {var func isArray(collection) ? arrayEachRight : baseEachRight;return func(collection, getIteratee(iteratee, 3));} baseEachRight 是通过调用 createBaseEach 函数并传入 baseForOwnRight 和 true 作为参数来创建的。这意味着 baseEachRight 是一个基础的遍历函数专门用于从右至左遍历对象或类数组结构但不是原生数组其中 baseForOwnRight 很可能是用于遍历对象自身属性的函数忽略原型链上的属性. forEachRight 是一个更高级别的函数它根据传入的 collection 是否是数组来决定使用哪个遍历函数。如果 collection 是数组它使用 arrayEachRight之前定义的专门用于数组的从右至左遍历。如果不是数组它则使用 baseEachRight。 6.arrayMap模块 function arrayMap(array, iteratee) {var index -1,length array null ? 0 : array.length,result Array(length);while (index length) {result[index] iteratee(array[index], index, array);}return result;}arrayMap函数用于对数组中的每个元素执行指定的操作函数iteratee并将结果存储在一个新的数组中返回。 7.baseMap模块 function baseMap(collection, iteratee) {var index -1,result isArrayLike(collection) ? Array(collection.length) : [];baseEach(collection, function(value, key, collection) {result[index] iteratee(value, key, collection);});return result;} baseMap 函数用于对集合collection中的每个元素执行指定的操作函数iteratee并将结果存储在一个新的数组中返回。此函数不仅适用于数组还适用于类数组对象array-like 对象。 8.map函数 function map(collection, iteratee) {var func isArray(collection) ? arrayMap : baseMap;return func(collection, getIteratee(iteratee, 3));} map 函数用于对集合collection中的每个元素执行指定的操作函数iteratee并将结果存储在一个新的数组中返回。此函数根据 collection 的类型来决定使用哪个具体的映射函数。 9.baseFlatten模块 function baseFlatten(array, depth, predicate, isStrict, result) {var index -1,length array.length;predicate || (predicate isFlattenable);result || (result []);while (index length) {var value array[index];if (depth 0 predicate(value)) {if (depth 1) {// Recursively flatten arrays (susceptible to call stack limits).baseFlatten(value, depth - 1, predicate, isStrict, result);} else {arrayPush(result, value);}} else if (!isStrict) {result[result.length] value;}}return result;} baseFlatten 的函数该函数用于将嵌套的数组即多维数组展平为一维数组。函数支持指定展平的深度并且可以根据条件选择是否严格展平。之前介绍过。 array: 要展平的数组。depth: 展平的深度。如果为 0则不进行展平如果为 1则展平一层如果为 Infinity则完全展平。predicate: 用于判断数组元素是否可以展平的函数。如果未提供则使用 isFlattenable 函数。isStrict: 布尔值表示是否严格展平。如果为 true则只展平符合 predicate 条件的元素如果为 false则将所有元素添加到结果数组中。result: 用于存储展平结果的数组。如果未提供则创建一个空数组。 10.flatMap函数 function flatMap(collection, iteratee) {return baseFlatten(map(collection, iteratee), 1);}flatMap 函数首先对集合中的每个元素应用指定的操作函数iteratee然后将生成的嵌套数组或结果数组展平一层。 11.flatMapDeep函数 function flatMapDeep(collection, iteratee) {return baseFlatten(map(collection, iteratee), INFINITY);} flatMapDeep函数首先对集合中的每个元素应用指定的操作函数iteratee然后将生成的嵌套数组或结果数组完全展平即无论嵌套多深都将所有元素展平为一维数组。 12.flatMapDepth函数 function flatMapDepth(collection, iteratee, depth) {depth depth undefined ? 1 : toInteger(depth);return baseFlatten(map(collection, iteratee), depth);} flatMapDepth 的函数该函数首先对集合中的每个元素应用指定的操作函数iteratee然后将生成的嵌套数组或结果数组展平到指定的深度。 四、总结 forEach, forEachRight, map, flatMap, flatMapDeep, flatMapDepth 都是用于遍历和操作数组或对象的函数。 forEach 和 forEachRight 的区别在于遍历顺序forEachRight 从右到左遍历。 map 类似于 forEach但 map 返回新数组而 forEach 返回原数组或对象。 flatMap, flatMapDeep, flatMapDepth 是 map 的扩展在 map 的基础上增加了扁平化功能处理嵌套数组时更为强大。flatMapDeep 比 flatMap 更深层次地扁平化嵌套数组。flatMapDepth 允许用户指定扁平化的深度提供了更大的灵活性。
http://www.w-s-a.com/news/991315/

相关文章:

  • 如何建设谷歌网站网站建设优点
  • 做网站的目标是什么产品宣传片制作公司
  • 柳州建设公司网站辽宁建设工程信息网评标专家入库
  • 合肥建设学校官方网站excel导入wordpress
  • 禹城网站设计做网站需要考虑哪些
  • 深圳做营销网站建设wordpress添加文章封面
  • 阿里云的网站建设方案织梦和wordpress哪个安全
  • 聊城网站建设公司电话wordpress怎么重新配置文件
  • 创业如何进行网站建设泰州公司注册
  • 免费网站建设培训学校手机百度高级搜索入口在哪里
  • 建站经验安徽六安发现一例新冠阳性检测者
  • 滨州内做网站系统的公司汕头网络营销公司
  • 苏州制作网站的公司哪家好wordpress google搜索
  • c语言做项目网站wordpress博客被书为什么还
  • 企业建站用什么系统网站建设补充协议模板
  • 常州网站关键字优化淘客网站怎么做排名
  • 全flash网站制作教程网站做进一步优化
  • 建设网站步骤是如何做自媒体和网站签约赚点击
  • 网站建设的闪光点网站 备案 拍照
  • 那些企业需要做网站九洲建设集团网站
  • 中山企业做网站昆明做网站价格
  • wordpress 新网站 代码网站可以做系统还原吗
  • 百度给做网站公司餐饮设计装饰公司
  • 专门卖医疗器械的网站网站建设方案一份
  • 吉林省建设安全监督站网站wordpress 4.7.5下载
  • 网页制作视频的网站建设营销策划公司
  • 玉雕网站建设八点品牌设计公司招聘
  • 服务器可以自己的网站吗flash 网站 源码
  • 湖南做网站 搜搜磐石网络网站注册收入
  • 北京软件网站开发装修设计培训机构