当前位置: 首页 > 知识库问答 >
问题:

javascript - 请问以下js排序代码,如何优化呢?

秦景同
2024-07-01
const sort_fun = {
    名称: (curr_data, is_desc) =>
        curr_data.children.sort((a, b) => {
            if (is_desc) {
                return a.pinyin[0] < b.pinyin[0] ? 1 : -1
            }
            return a.pinyin[0] < b.pinyin[0] ? -1 : 1
        }),
    类型: (curr_data, is_desc) =>
        curr_data.children.sort((a, b) => {
            if (is_desc) {
                return a.suffix < b.suffix ? 1 : -1
            }
            return a.suffix < b.suffix ? -1 : 1
        }),
    大小: (curr_data, is_desc) =>
        curr_data.children.sort((a, b) => {
            if (is_desc) {
                return a.bytes < b.bytes ? 1 : -1
            }
            return a.bytes < b.bytes ? -1 : 1
        }),
    时间: (curr_data, is_desc) =>
        curr_data.children.sort((a, b) => {
            if (is_desc) {
                return a.timestamp.mtime < b.timestamp.mtime ? 1 : -1
            }
            return a.timestamp.mtime < b.timestamp.mtime ? -1 : 1
        }),
}

因为 a.pinyin[0] 的原因,我不知道怎么用 a[..] 的方式简化代码

谢谢

共有3个答案

杨凯旋
2024-07-01
function sortFactory(names) {
  return (curr_data, is_desc) =>
        curr_data.children.sort((a, b) => {
            if (is_desc) {
                return getValue(a, names) < getValue(b, names) ? 1 : -1
            }
            return getValue(a, names) < getValue(b, names) ? -1 : 1
        });
}

function getValue(obj, names) {
  return names.reduce((pre, cur) => pre[cur], obj)
}
蒋斯伯
2024-07-01
function buildSort<T, D>(getData: (item: T) => D, desc = false) {
    return desc
        ? (a: T, b: T) => (getData(a) < getData(b) ? 1 : -1)
        : (a: T, b: T) => (getData(a) < getData(b) ? -1 : 1)
}

// 名称

curr_data.children.sort(buildSort(i => i.pinyin[0]))

// 类型

curr_data.children.sort(buildSort(i => i.suffix))

// 大小

curr_data.children.sort(buildSort(i => i.bytes))

// 时间

curr_data.children.sort(buildSort(i => i.timestamp.mtime))
麻昌翰
2024-07-01

将原有的四个独立的排序函数合并为一个通用的 sortData 方法,通过传入不同的参数来适应不同的属性和排序方向。

const sortFun = {
    // 通用排序方法
    sortData: function(curr_data, prop, is_desc) {
        // 根据 is_desc 的值确定排序的方向
        const direction = is_desc ? 1 : -1;

        // 使用 sort 方法对 curr_data.children 数组进行排序
        // 注意这里使用了箭头函数
        return curr_data.children.sort((a, b) => {
            // 通过 prop 参数指定的属性名获取 a 和 b 的属性值
            // 如果属性是嵌套的,例如 'timestamp.mtime',这里会递归地访问到这个深层属性
            const aValue = prop.split('.').reduce((o, i) => o[i], a);
            const bValue = prop.split('.').reduce((o, i) => o[i], b);

            // 比较两个属性值
            if (aValue < bValue) {
                // 如果 a 的属性值小于 b 的属性值,则返回负数(升序)或正数(降序),根据 direction 的值
                return direction * -1;
            }
            if (aValue > bValue) {
                // 如果 a 的属性值大于 b 的属性值,则返回正数(升序)或负数(降序),根据 direction 的值
                return direction * 1;
            }
            // 如果两个属性值相等,则返回 0,表示它们在排序中视为相等
            return 0;
        });
    },
};

// 使用示例:
// 调用 sortData 方法进行排序
// 第一个参数是当前要排序的数据
// 第二个参数是要基于哪个属性进行排序
// 第三个参数是是否为降序排序
sortFun.sortData(curr_data, 'pinyin', false);   // 升序排序 pinyin 属性
sortFun.sortData(curr_data, 'suffix', true);    // 降序排序 suffix 属性
sortFun.sortData(curr_data, 'bytes', false);    // 升序排序 bytes 属性
sortFun.sortData(curr_data, 'timestamp.mtime', true); // 降序排序 timestamp.mtime 属性
 类似资料:
  • 我认为代码(如下)已经优化(只需使用比相同逻辑的初始版本更少的变量) > 在优化过程中,我应该考虑哪些因素? 这是代码(也在jsfiddle上) 这是代码的解释。“处理”函数在数组中查找相同的值,对于每个相同的值,它通过将一个数字挂起到该值来更改值,“数字”表示它在数组中找到的值的计数。 例如arr=["x","x","y","z"]将返回["x(1)","x(2)","y","z"]"y"和"z

  • 请问,想要忽略大小写,请问应该如何优化呢?

  • 本文向大家介绍分享javascript实现的冒泡排序代码并优化,包括了分享javascript实现的冒泡排序代码并优化的使用技巧和注意事项,需要的朋友参考一下 冒泡排序:就是将一个数组中的元素按照从大到小或者从小到大的顺序进行排列。 第一轮比较:8,7,6,5,4,3,2,1,9      交换了8次        i=0   j=array.length-1-i 第二轮比较:7,6,5,4,3,

  • 请问如何让ar1这种ip排序,js可以实现吗? 另外,我希望是用换行符分割(现在是,分割),排序后也是一行一个。请问可以实现吗

  • 本文向大家介绍请解释下如下js代码对数组排序后的输出结果相关面试题,主要包含被问及请解释下如下js代码对数组排序后的输出结果时的应答技巧和注意事项,需要的朋友参考一下 javascript sort默认排序原理

  • JavaScript代码优化 1、慎用全局变量 为什么要慎用全局变量原因如下 1、全局变量定义在全局执行上下文,是所有作用域链的顶端 2、全局执行上下文一直存在于上下文执行站,直到程序退出 3、如果某个局部作用域出现了同名变量则会遮蔽或污染全局 2、缓存全局变量 其实就是在程序执行过程中,将使用中无法避免的全局变量缓存到局部 代码演示如下 1、普通写法: function getBt

  • 如何将两个方法合并成一个方法 如图parentValues = ['BC', 'BC-SRV', 'BC-SRV-COM'], 想得到的是选中的树组arrSelectedFacets = ['BC-SRV-COM-FTP', 'BC-SRV-COM-TEL'] 如果 BC-SRV-COM 下的子节点都选中,则arrSelectedFacets=['BC-SRV-COM']

  • 主要内容:src/runoob/heap/HeapSort.java 文件代码:上一节的堆排序,我们开辟了额外的空间进行构造堆和对堆进行排序。这一小节,我们进行优化,使用原地堆排序。 对于一个最大堆,首先将开始位置数据和数组末尾数值进行交换,那么数组末尾就是最大元素,然后再对W元素进行 shift down 操作,重新生成最大堆,然后将新生成的最大数和整个数组倒数第二位置进行交换,此时到处第二位置就是倒数第二大数据,这个过程以此类推。 整个过程可以用如下图表示: Java 实