日常开发小汇总(5)数组克隆、伪数组转换为真数组、随机排序

  1. slice 切割数组实现克隆是浅拷贝
bash 复制代码
let arr = [1,2, {name:1}]
let newarr = arr.slice(0);
console.log(newarr) //[1,2, {name:1}]
newarr[2].name = 666;
console.log(arr[2].name);//666  
  1. JSON实现克隆 深拷贝
bash 复制代码
let arr = [1,2, {name:1}]
let newarr = JSON.parse( JSON.stringify(arr) )
newarr[2].name = 666;
console.log(arr[2].name) //1

3.Object.assign() 浅拷贝

bash 复制代码
let arr = [1,2, {name:1}]
let newarr = Object.assign([],arr)
newarr[2].name = 666;
console.log(arr[2].name) //666
  1. 转换为真数组
javascript 复制代码
let obj = {
	0:"1",
	1:"2",
	length: 2
}
let arr = Array.prototype.slice.call(obj,0)
//也可以写成Array.prototype.slice.call(obj)
console.log(arr)
  1. 数组随机排序
javascript 复制代码
let ar = [1,2,3,4,5,6,7,8,9,10]
ar.sort(()=> (Math.random()-0.5))
相关推荐
山有木兮木有枝_14 分钟前
JavaScript 设计模式--单例模式
前端·javascript·代码规范
一大树28 分钟前
Vue3 开发必备:20 个实用技巧
前端·vue.js
颜渊呐33 分钟前
uniapp中APPwebview与网页的双向通信
前端·uni-app
10年前端老司机1 小时前
React 受控组件和非受控组件区别和使用场景
前端·javascript·react.js
夏晚星1 小时前
vue实现微信聊天emoji表情
前端·javascript
停止重构1 小时前
【方案】前端UI布局的绝技,响应式布局,多端适配
前端·网页布局·响应式布局·grid布局·网页适配多端
極光未晚1 小时前
TypeScript在前端项目中的那些事儿:不止于类型的守护者
前端·javascript·typescript
ze_juejin1 小时前
Vue3 + Vite + Ant Design Vue + Axios + Pinia 脚手架搭建
前端·vue.js
Rrvive1 小时前
原型与原型链到底是什么?
javascript
lichenyang4531 小时前
React项目(移动app)
前端