受下划线库启发,努力重写调用函数
P粉990008428
P粉990008428 2024-03-31 09:42:10
0
2
431

我是一个初学者,正在尝试重写下划线函数_.invoke。 我正在尝试创建该函数,以便它返回一个数组,其中包含对集合中的每个值调用该方法的结果。

_.invoke = function(collection, methodName) {
  var result = [];
  if (Array.isArray(collection)) {
    for (let i = 0; i < collection.length; i++) {
      methodName.call(collection[i])
      var value = collection[i][methodName]
      result.push(value)
    }
  }
  return result
}

我认为我的问题出在这一行:

methodName.call(collection[i]) - 想调用对象 collection[i] 上的方法,但我想传递一些参数(如果它们包含在单元测试中)。

到目前为止,我已经尝试使用测试: typeof(methodName) === "function" 并编写一个函数来测试该方法是否是一个函数。

P粉990008428
P粉990008428

全部回复(2)
P粉165522886

在这里您可以使用参数进行调用。

_.invoke = function(collection, methodName, ...args) {
  if (!Array.isArray(collection)) {
     return [];
  }
  const out = []; 
  for(const item of collection){
    if(typeof item[methodName] === 'function')
      out.push(item[methodName].apply(item, args));
    }
  }
  return out;
}

要测试所有项目都有一个方法:

const collection = [...];
const allHaveMethod = _.invoke(collection, 'method', 'arg1', 'arg2').length === collection.length;
P粉413704245

你的意思是这样的吗?

const myArr = [
  { cons:function(args) { return args } },
  { cons:function(args) { return args["bla"] } },
]

const _ = {};
_.invoke = (collection, methodName, ...args) => !Array.isArray(collection) ? [] : collection
.filter(item => typeof item[methodName] === 'function')
.map(item => item[methodName].apply(item, args));

const res = _.invoke(myArr,"cons",{"bla":"hello"})
console.log(res)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板