首頁 > web前端 > js教程 > 解決JavaScript中數組排序sort不發生改變

解決JavaScript中數組排序sort不發生改變

hzc
發布: 2020-06-15 09:28:16
轉載
3493 人瀏覽過

解決JavaScript中數組排序sort不發生改變

最近在做一個項目,Ajax從後台返回資料後,前端用js處理時,發現無論如何使用sort排序,最終要么是沒改變,要嘛只改變最後一次的排序,折騰了很久,最後查了查資料才發現,js中區分淺拷貝和深拷貝。

    var provinceConfirmedCount = data;
    var provinceDeadCount = data;
    var provinceCuredCount = data;

    provinceConfirmedCount.sort(sortBy(("provinceConfirmedCount")));
    provinceDeadCount.sort(sortBy(("provinceDeadCount")));
    provinceCuredCount.sort(sortBy(("provinceCuredCount")));

    console.log(provinceConfirmedCount); //不生效
    console.log(provinceDeadCount); //不生效
    console.log(provinceCuredCount); //生效

//比较数组对象
function sortBy(field) {
    return function(a,b) {
        return parseInt(b[field]) - parseInt(a[field]);
    }
}
登入後複製

淺拷貝、深拷貝與賦值

這三個的區別無法就是改變資料的時候,是如何改變,為了簡單明了,用一張表最快理解:

##第一層為基本資料型別原資料中包含子物件賦值#淺拷貝#深拷貝

#是否指向同一物件
#是會使原始資料一同改變會使原始資料一同改變
不會使原始資料一同改變會使原始資料一同改變

#不會使原始資料一同改變
不會讓原始資料一同改變

解決方案

###既然知道了原理,這裡的需求是需要全部改變,所以我們可以採用JQuery中的extend方法來處理:###
    var provinceConfirmedCount = $.extend([], data);
    var provinceDeadCount = $.extend([], data);;
    var provinceCuredCount = $.extend([], data);;

    provinceConfirmedCount.sort(sortBy(("provinceConfirmedCount")));
    provinceDeadCount.sort(sortBy(("provinceDeadCount")));
    provinceCuredCount.sort(sortBy(("provinceCuredCount")));

    console.log(provinceConfirmedCount);
    console.log(provinceDeadCount);
    console.log(provinceCuredCount);
登入後複製
###語法:$.extend( target, [object1], [objectN] )其中, target為目標類型,這裡我用的是陣列[],還可以是{},可依實際情況處理。 從後面的[object1], [objectN]我們可以知道,extend是可以將多個待處理物件合併成一個目標類型的物件。 ######推薦教學:《###JS教學###》###

以上是解決JavaScript中數組排序sort不發生改變的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:juejin.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板