js深拷贝 和封装的js排序方法sort(前端网备份)

匿名 (未验证) 提交于 2019-12-02 23:38:02

先来说浅拷贝
var arr = ["a","b"];
var arrCopy = arr;
arrCopy[1] = "c";
arr // => ["a","c"]

然后再来说一下简易版深拷贝封装
function clone(obj) {
var c = {};
c = JSON.parse(JSON.stringify(obj));
return c;
}
至于序列化为何会深拷贝,参考
https://www.imooc.com/article/70653

// arr是需要传的对象数组;obj
// field是需要排序对象数组的字段;string
// sort: string
function sort(arr,field,sort) {
if(sort==null || sort==''){
sort="asc";
}
var len = arr.length;
for (var i = 0; i < len; i++) {
for (var j = 0; j < len - 1 - i; j++) {
if(sort=="desc"){
if (arr[j][field] < arr[j + 1][field]) {
var temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}else{
if (arr[j][field] > arr[j + 1][field]) {
var temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
}
return arr;
}

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!