Knockout中ko.utils中处理数组的方法集合

每一套框架基本上都会有一个工具类,如:Vue中的Vue.utilKnockout中的ko.utilsjQuery直接将一些工具类放到了$里面,如果你还需要更多的工具类可以试试lodash。本文只介绍一下Knockout中ko.utils中处理数组的一些方法。

ko.utils.arrayForEach(array, callback)

与Array.prototype.forEach作用一致。提供函数(回调函数)对数组的每个元素执行一次。使用方法:

var arr = [1, 2, 3, 4];
ko.utils.arrayForEach(arr, function(el, index) {console.log(el)
});

上面分别输出:1234

ko.utils.arrayForEach源码:

ko.utils.arrayForEach = function (array, action) {for (var i = 0, j = array.length; i < j; i++)action(array[i], i);
}

ko.utils.arrayMap(array, callback)

与Array.prototype.map作用一致。返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。使用方法:

var arr = [1, 2, 3, 4];
var newArr = ko.utils.arrayMap(arr, function(el, index) {return el + 1;
});

上面得到的newArr为:[2, 3, 4, 5]

ko.utils.arrayMap源码:

ko.utils.arrayMap = function (array, mapping) {array = array || [];var result = [];for (var i = 0, j = array.length; i < j; i++)result.push(mapping(array[i], i));return result;
}

ko.utils.arrayFilter(array, callback)

与Array.prototype.filter作用一致。使用指定的函数测试所有元素,并创建一个包含所有通过测试的元素的新数组。使用方法:

var arr = [1, 2, 3, 4];
var newArr = ko.utils.arrayFilter(arr, function(el, index) {return el > 2;
});

上面得到的newArr为:[3, 4]

ko.utils.arrayFilter源码:

ko.utils.arrayFilter = function (array, predicate) {array = array || [];var result = [];for (var i = 0, j = array.length; i < j; i++)if (predicate(array[i], i))result.push(array[i]);return result;
}

ko.utils.arrayIndexOf(array, item)

与Array.prototype.indexOf作用一致。返回给定元素能找在数组中找到的第一个索引值,否则返回-1。使用方法:

var arr = [1, 2, 3, 4];
var index = ko.utils.arrayIndexOf(arr, 2);

上面得到的index值为1

ko.utils.arrayIndexOf源码:

ko.utils.arrayIndexOf = function (array, item) {if (typeof Array.prototype.indexOf == "function")return Array.prototype.indexOf.call(array, item);for (var i = 0, j = array.length; i < j; i++)if (array[i] === item)return i;return -1;
}

ko.utils.arrayRemoveItem(array, itemToRemove)

从数组中删除一个指定值的元素。使用方法:

var arr = [1, 2, 3, 4, 2];
ko.utils.arrayRemoveItem(arr, 2);

上面arr现在为[1, 3, 4, 2]

ko.utils.arrayRemoveItem源码:

ko.utils.arrayRemoveItem = function (array, itemToRemove) {var index = ko.utils.arrayIndexOf(array, itemToRemove);if (index > 0) {array.splice(index, 1);}else if (index === 0) {array.shift();}
}

ko.utils.arrayGetDistinctValues(array)

对数组进行去重(如果数组长度很大效率会很低),返回去重之后的新数组。使用方法:

var arr = [1, 2, 3, 4, 2, 4, '1'];
var newArr = ko.utils.arrayGetDistinctValues(arr);

得到的newArr值为[1, 2, 3, 4, '1']

ko.utils.arrayGetDistinctValues源码:

ko.utils.arrayGetDistinctValues = function (array) {array = array || [];var result = [];for (var i = 0, j = array.length; i < j; i++) {if (ko.utils.arrayIndexOf(result, array[i]) < 0)result.push(array[i]);}return result;
}

ko.utils.arrayFirst(array, callback[, thisArg])

Array.prototype.find方法类似(命名与find偏差太大了)。返回第一个满足条件的元素。使用方法:

var arr = [{name: "apple"},{name: "banana"},{name: "cherries"}
];
var item = ko.utils.arrayFirst(arr, function(el, index){return el.name === "banana";
})

ko.utils.arrayFirst源码:

ko.utils.arrayFirst = function (array, predicate, predicateOwner) {for (var i = 0, j = array.length; i < j; i++)if (predicate.call(predicateOwner, array[i], i))return array[i];return null;
}

ko.utils.arrayPushAll(array, valuesToPush)

将数组valuesToPush合并到数组array中。使用方法:

var arr = [1, 2, 3];
ko.utils.arrayPushAll(arr, [4, 5]);

最后arr的值为[1, 2, 3, 4, 5]

ko.utils.arrayPushAll源码:

ko.utils.arrayPushAll = function (array, valuesToPush) {if (valuesToPush instanceof Array)array.push.apply(array, valuesToPush);elsefor (var i = 0, j = valuesToPush.length; i < j; i++)array.push(valuesToPush[i]);return array;
}

ko.utils.addOrRemoveItem(array, value, included)

includedtrue,则array中含有value不处理,没有则添加; includedfalse,则array中含有value删除,没有则不处理。 使用方法:

var arr = [1, 2, 3];ko.utils.addOrRemoveItem(arr, 4, true); /// arr为[1, 2, 3, 4]// 或者
ko.utils.addOrRemoveItem(arr, 4, false); /// arr为[1, 2, 3]// 或者
ko.utils.addOrRemoveItem(arr, 2, true); /// arr为[1, 2, 3]// 或者
ko.utils.addOrRemoveItem(arr, 2, false); /// arr为[1, 3]

ko.utils.addOrRemoveItem源码:

addOrRemoveItem: function(array, value, included) {var existingEntryIndex = ko.utils.arrayIndexOf(ko.utils.peekObservable(array), value);if (existingEntryIndex < 0) {if (included)array.push(value);} else {if (!included)array.splice(existingEntryIndex, 1);}
}

ko中基本上就这些处理数组的方法了,如果你知道ko中有这些方法,那么在做兼容比较旧的浏览器(IE8及以下)的开发能让你轻松很多。

转自:https://www.xiaoboy.com/topic/ko-utils-array-function.html

转载于:https://www.cnblogs.com/tangge/p/10333161.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/249724.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

$nextTick 源码

x现在没时间&#xff0c;留个坑 转载于:https://www.cnblogs.com/smzd/p/11634665.html

java 发布订阅

1.发布者接口 package com.yy.subpub; /** * Description: 发布者接口 * author: leijing * date: 2016年9月29日 下午5:07:20 */ public interface IPublisher<M> { /** * Description: 向订阅器发布消息 * param subscribePublish 订阅器 * param message 消息 * para…

.NET Core Session的简单使用

前言 在之前的.NET 里&#xff0c;我们可以很容易的使用Session读取值。那今天我们来看看 如何在.NET Core中读取Session值呢&#xff1f; Session 使用Session之前&#xff0c;我们需要到Startup.cs中配置我们的服务如下&#xff1a; ①在ConfigureServices中加入&#xff1a;…

EasyNVR内网摄像机接入网关+EasyNVS云端管理平台,组件起一套轻量级类似于企业级萤石云的解决方案...

背景分析 对于EasyNVR我们应该都了解&#xff0c;主要应用于互联安防直播&#xff0c;对于EasyNVR&#xff0c;我们可以清楚的发现&#xff0c;EasyNVR的工作机制是EasyNVR拉取摄像机的RTSP/Onvif视频流&#xff0c;然后客户端可以通过访问EasyNVR服务端实现流分发&#xff0c;…

java.util.Queue用法

队列是一种特殊的线性表&#xff0c;它只允许在表的前端&#xff08;front&#xff09;进行删除操作&#xff0c;而在表的后端&#xff08;rear&#xff09;进行插入操作。进行插入操作的端称为队尾&#xff0c;进行删除操作的端称为队头。队列中没有元素时&#xff0c;称为空队…

Vim删除文件到行首或者行尾

vim用的不是很熟练&#xff0c;只是有时候需要的时候会学习一下 我们知道&#xff0c;vim有三种模式&#xff0c;一种是一般模式&#xff0c;一种是编辑模式&#xff0c;另外一种是命令行模式 在一般模式下&#xff0c;可以进行删除&#xff0c;复制粘贴等操作&#xff0c;在编…

新版本微信导致的ios表单bug

解决方法如下&#xff1a; $(document).delegate(input, textarea, select, blur, function(){setTimeout(function(){$(html).animate({height: 100.1vh}, 100, function(){$(this).animate({height: 100vh}, 1)})},100); }); 转载于:https://www.cnblogs.com/qdlhj/p/1033676…

Golang的值类型和引用类型的范围、存储区域、区别

常见的值类型和引用类型分别有哪些&#xff1f; 值类型&#xff1a;基本数据类型 int 系列, float 系列, bool, string 、数组和结构体struct&#xff0c;使用这些类型的变量直接指向存在内存中的值&#xff0c;值类型的变量的值通常存储在栈中。 引用类型&#xff1a;指针、sl…

python3之time模块

时间戳1: import time2: print(time.time()) 可读的时间格式1: import time2: print(time.ctime())3: later time.time() 6004: print(time.ctime(later)) 结果1: Wed Jan 30 17:11:49 20192: Wed Jan 30 17:21:49 2019 暂停程序(进程或者线程)1: time.sleep(secs) 计时时钟1…

网络规划设计(项目类业务)

前期准备&#xff1a;找经开部要到当地的现场结构图 1.和通信段约好时间&#xff0c;实地跑一趟&#xff0c;找到光缆、电缆的原汇聚点。 2.与车间人员沟通&#xff0c;看是否要迁汇聚点&#xff0c;倘若迁汇聚点&#xff0c;迁到哪里。 3.怎么从光缆/电缆的旧址迁到新址&#…

RPC框架实现原理

一、什么是RPC框架&#xff1f; RPC&#xff0c;全称为Remote Procedure Call&#xff0c;即远程过程调用&#xff0c;是一种计算机通信协议。 比如现在有两台机器&#xff1a;A机器和B机器&#xff0c;并且分别部署了应用A和应用B。假设此时位于A机器上的A应用想要调用位于B机…

jQuery安装

http://www.runoob.com/jquery/jquery-install.html 网页中添加jQuery&#xff1a; 方法一&#xff1a;可以从http://jquery.com/download/ 下载jQuery库 方法二&#xff1a;从CDN中载入jQuery 下载 jQuery 有两个版本的 jQuery 可供下载&#xff1a; Production version - 用于…

redhat相关配置

网络配置&#xff1a; vi /etc/sysconfig/network-scripts/ifcfg-eth BOOTPROTOstaticONBOOTyesIP配置IPADDR192.168.31.102NETMASK255.255.255.0GATEWAY192.168.31.1DNS1192.168.31.1redhat6&#xff1a;防火墙&#xff1a;1. 永久性生效开启&#xff1a;chkconfig iptables o…

zookeeper入门系列

zookeeper可谓是目前使用最广泛的分布式组件了。其功能和职责单一&#xff0c;但却非常重要。 在现今这个年代&#xff0c;介绍zookeeper的书和文章可谓多如牛毛&#xff0c;本人不才&#xff0c;试图通过自己的理解来介绍zookeeper&#xff0c;希望通过一个初学者的视角来学习…

java.lang.NumberFormatException: multiple points错误问题

最近项目一直会出现时间转换报错&#xff0c;一直不知道是什么问题??? java.lang.NumberFormatException: multiple pointsat sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1110)at java.lang.Double.parseDouble(Double.java:540)at java.text.Dig…

plsql查询数据中文乱码

在plsql中进行表数据查询的时候&#xff0c;发现查询出来的中文居然显示为乱码&#xff0c;通过查找资料解决该问题。 1、查看数据的编码&#xff08;语句&#xff1a;select * from v$nls_parameters&#xff09; 发现显示的语言不是我们常用的GBK模式 2、配置本机语言环境变量…

Zookeeper的功能以及工作原理

1.ZooKeeper是什么&#xff1f; ZooKeeper是一个分布式的&#xff0c;开放源码的分布式应用程序协调服务&#xff0c;是Google的Chubby一个开源的实现&#xff0c;它是集群的管理者&#xff0c;监视着集群中各个节点的状态根据节点提交的反馈进行下一步合理操作。最终&#xf…

前端学习总结——CSS布局方式之传统布局

传统布局 传统布局即是早期在平板电脑、智能手机等移动设备并不流行的时候使用的布局方式。 一、表格布局 例如&#xff1a;采用表格方式实现如下简单模型的布局 &#xff08;1&#xff09;固定布局 即用具体的像素值来确定模型的宽和高等值。 HTML代码如下所示 <tabl…

aspose word for java去除目录文字蓝色样式以及文字下方蓝色下划线

//去除目录文字蓝色样式以及文字下方蓝色下划线for(FieldStart field: (Iterable<FieldStart>)doc.getChildNodes(NodeType.FIELD_START, true)){if (field.getFieldType() FieldType.FIELD_HYPERLINK){FieldHyperlink hyperlink (FieldHyperlink)field.getField();//判…

[POI2007]MEG-Megalopolis

传送门&#xff1a;嘟嘟嘟 第一反应是树链剖分&#xff0c;但是太长懒得写&#xff0c;然后就想出了一个很不错的做法。 想一下&#xff0c;如果我们改一条边&#xff0c;那么影响的只有他的子树&#xff0c;只要先搞一个dfs序&#xff0c;为什么搞出这个呢&#xff1f;因为有一…