先上代碼:function fastSort(arr, isDown=false){ if(getVarType(arr) !== "array" || arr.length <= 1){ return arr; } var mid = arr.splice(Math.floor((arr.length-1)/2), 1)[0], left = [], right = []; for(var i=0; i<arr.length; i++){ arr[i] > mid? right.push(arr[i]): left.push(arr[i]); } [a, b] = isDown?[right, left]: [left, right]; return fastSort(a).concat(mid, fastSort(b));}var a = [417,7,9,42,3,3,43,90,0,66];fastSort(a);寫了個快速排序,想用解構(gòu)賦值的方式 實現(xiàn)升序降序功能,然后這種寫法得到的數(shù)組是:[0, 3, 3],大概調(diào)試看了下發(fā)現(xiàn) 最后的return傳的參數(shù)把a,b 改為left,right,結(jié)果就沒問題。或者a,b的賦值改為var a = isDown?right: left, b = isDown?left: right;結(jié)果也是沒問題,所以猜測會是和解構(gòu)賦值這種寫法有關(guān)么?PS:控制臺打了下斷點,發(fā)現(xiàn)用 return fastSort(a).concat(mid, fastSort(b)) 這種寫法fastSort(b) 都沒有調(diào)用就直接return 最終結(jié)果了,所以導致得到的數(shù)組是 [0,3,3].
解構(gòu)賦值能否在遞歸中使用?
回首憶惘然
2018-12-12 14:15:33