繁体   English   中英

如何将 JavaScript ES6 箭头函数作为参数传递

[英]How can I Pass a JavaScript ES6 Arrow Function as a Parameter

我正在尝试.sort()对象数组,但我的 javascript 知识不够强大,无法重写比较器函数以接受箭头函数来查找对象上的key ,而不是使用字符串。 任何重构这方面的帮助将不胜感激:

我的比较功能:

compareValues = (key, order = "ascending") => {
      let result = 0;

      return function(lhs, rhs) {
        if (!(lhs.hasOwnProperty(key) && rhs.hasOwnProperty(key))) {
          return result; // property is missing; comparison is impossible
        }

        const l = lhs[key].toLowerCase() || lhs[key];
        const r = rhs[key].toLowerCase() || rhs[key];

        result = (l > r) ? 1 : (l < r) ? -1 : 0;

        return result * (order === "ascending") ? 1 : -1;
      };
    };

以传统方式使用:

objects.sort(compareValues("name")); // or
objects.sort(compareValues("name", descending));

目标是能够这样使用它:

objects.sort(compareValues(o => o.name));

...但坦率地说,我直到最近才经常使用 JS,所以我很讨厌它。

也许是这样的:

const compareValues = (pickProp, order = 'ascending') => {
    let result = 0

    return (lhs, rhs) => {
        const l = pickProp(lhs) // pickProp is passed #first-class
        const r = pickProp(rhs)
        if (!l && !r) {
            return 0 // Quick callout here, comparators only ever return -1, 0, or 1.
        }

        result = l > r ? 1 : l < r ? -1 : 0

        // Leveraging your default values here for cleaner signature
        return result * (order === 'ascending') ? 1 : -1
    }
}

list.sort(compareValues(o => o.name))
// or even 
list.sort(compareValues(o => o.name), 'descending')

我相信这与你的问题一致。

我认为你越接近你想要的东西是这样的:

 let compareValues = (key, order = "ascending") => { let result = 0; return function(lhs, rhs) { if (!(key(lhs) && key(rhs))) { return result; // property is invalid; comparison is impossible } const l = key(lhs).toLowerCase() || key(lhs); const r = key(rhs).toLowerCase() || key(rhs); result = (l > r) ? 1 : (l < r) ? -1 : 0; return result * (order === "ascending") ? 1 : -1; }; }; let objects = [{ "name": "Mary" }, { "name": "John" }]; objects.sort(compareValues(o => o.name)); console.log(objects);

我认为您不需要对对象执行检查以查看它们是否具有特定属性,因为您肯定知道。 所以这就是我的看法。


 const comparer= (select, descend = false) => (a, b) => { let lhs = select(a); let rhs = select(b); if (lhs < rhs) return descend ? 1 : -1; if (lhs > rhs) return descend ? -1 : 1; return 0; } let arr = [{ id: 1, name: "Clara" }, { id: 2, name: "Abraham" }, { id: 3, name: "Brian" }] arr.sort(comparer(o => o.name)) console.log(arr); arr.sort(comparer(o => o.name, true)) console.log(arr);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM