gpt4 book ai didi

javascript - 如何对div数据进行降序排序

转载 作者:行者123 更新时间:2023-12-01 00:25:42 24 4
gpt4 key购买 nike

我有一个显示特定颜色百分比的 div。我想按降序对 div 百分比进行排序。如何进行?下面是我的代码

function displayLegend() {
for (var key in colorVariable1) {
let percentage = (countVariable1[key] / totalPCICount) * 100;
if(percentage) {
percentage = percentage.toFixed(2);
}
var line = document.createElement("div");
line.innerHTML = '<span class="box" style=" background: ' + colorVariable1[key] + ';"></span><span>' + key + '(' + percentage + '%)</span>';
document.getElementById("legendInfo").appendChild(line);
}
}

下面是图片。我想对百分比部分进行排序。

enter image description here

<小时/>

最佳答案

您可能需要首先以结构化形式存储数据,以便能够对其进行排序。

我重写了您的示例以展示我的想法 - 未经测试。

var values = []; // holder for rows

for (var key in colorVariable1) {
let percentage = (countVariable1[key] / totalPCICount) * 100;
if(percentage) {
percentage = percentage.toFixed(2);
} else {
percentage = 0;
}

// row definition
let entry = {
value: percentage,
html: '<span class="box" style=" background: ' + colorVariable1[key] + ';"></span><span>' + key + '(' + percentage + '%)</span>';
}

values.push(entry); // add row to holder
}

// sort rows in holder by value (percentage)
// see: https://stackoverflow.com/questions/979256/sorting-an-array-of-objects-by-property-values
values.sort(function(a, b) {
return parseFloat(b.value) - parseFloat(a.value);
});

// add sorted lines
for(var i in values){
var line = document.createElement("div");
line.innerHTML = values[i].html;
document.getElementById("legendInfo").appendChild(line);
}

关于javascript - 如何对div数据进行降序排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59032170/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com