有没有一种用TypeScript在数组中查找项的规范方法?
ES6+支持这种简单/干净的方法
[{"id":1}, {"id":-2}, {"id":3}].find(myObj => myObj.id < 0) // returns {"id":-2}
TypeScript实现了许多ES6+功能,并将继续这样做。它似乎至少有一个很好的解决方案,所以:
考虑到易用性、现代最佳实践和通过简单性实现的优雅,如何使用TypeScript在数组中找到项?
(稍微重复一下问题以寻求最佳方法)
备注
发布于 2015-07-16 22:52:48
第1部分-多边形填充
对于还没有实现它的浏览器,可以使用array.find
的polyfill。Courtesy of MDN。
if (!Array.prototype.find) {
Array.prototype.find = function(predicate) {
if (this == null) {
throw new TypeError('Array.prototype.find called on null or undefined');
}
if (typeof predicate !== 'function') {
throw new TypeError('predicate must be a function');
}
var list = Object(this);
var length = list.length >>> 0;
var thisArg = arguments[1];
var value;
for (var i = 0; i < length; i++) {
value = list[i];
if (predicate.call(thisArg, value, i, list)) {
return value;
}
}
return undefined;
};
}
第二部分-接口
您需要扩展开放数组接口以包含find
方法。
interface Array<T> {
find(predicate: (search: T) => boolean) : T;
}
当它到达TypeScript时,编译器会给你一个警告,提醒你删除它。
第三部分-使用它
变量x
将具有预期的类型...{ id: number }
var x = [{ "id": 1 }, { "id": -2 }, { "id": 3 }].find(myObj => myObj.id < 0);
发布于 2016-03-03 03:18:27
对于某些项目,在tsconfig.json
中将目标设置为es6
会更容易一些。
{
"compilerOptions": {
"target": "es6",
...
发布于 2016-05-23 22:51:49
使用tsconfig.json,您也可以像这样瞄准es5:
{
"compilerOptions": {
"experimentalDecorators": true,
"module": "commonjs",
"target": "es5"
}
...
https://stackoverflow.com/questions/31455805
复制相似问题