var fruit=[7,10,32,6,9,4];
document.write(fruit+'<br>');
fruit.sort(sortFun);
document.write(fruit);
function sortFun(ar1,ar2){
if(ar1>ar2){
return 1;
}else if(ar1<ar2){
return -1;
}else{
return 0;
}
}
Comment ce code organise-t-il les éléments du tableau?? S'il vous pla?t, donnez-moi une explication détaillée. Merci
學(xué)習(xí)是最好的投資!
Pour vous aider à comprendre, vous pouvez essayer d'appeler directement la méthode de tri?:
var fruit=[7,10,32,6,9,4];
fruit.sort();
Le résultat renvoyé est?: [10, 32, 4, 6, 7, 9]
[10, 32, 4, 6, 7, 9]
而不是期待中的:[ 4, 6, 7, 9, 10, 32]
為什么會這樣呢?
因為這是數(shù)組原型鏈上的sort()方法,即Array.prototype.sort()
Au lieu de l'attendu?: [4, 6, 7, 9, 10, 32] code>
Pourquoi cela se produit-il??
Parce qu'il s'agit de la méthode sort() sur la cha?ne de prototypes de tableau, c'est-à-dire Array.prototype.sort()
.
Comment étudier cette méthode sort() en profondeur?:
1 Vous pouvez aller sur le document mdn https://developer.mozilla.org...
2 Vous pouvez aller dans "Javascript Advanced Programming", mais en mode avancé. le design n'est pas terminé
fruit.sort(sortFun);
sort 數(shù)組的排序方法;
用法:
var arr=[];
arr.sort(function(a,b){
})
比如從小到大:
var arr=[9,5,6];
arr.sort(function(a,b){
return a-b;
})
fruit.sort(sortFun);中的sortFun就相當(dāng)于arr.sort(function(a,b){})
中的function(a,b){};
if(ar1>ar2){
return 1;
}else if(ar1<ar2){
return -1;
}else{
return 0;
}就相當(dāng)于return a-b;
Vous aurez peut-être besoin de cet article https://developer.mozilla.org...