当前位置: 首页 > news >正文

app专业定制开发网站优化系统

app专业定制开发,网站优化系统,做网站图片广告推广怎么忽悠人的,七彩发光字生成器开发中我们经常需要复制一个对象。如果直接用赋值会有下面问题: 8.1 浅拷贝 首先浅拷贝和深拷贝只针对引用类型 浅拷贝:拷贝的是地址 常见方法: 1.拷贝对象:Object.assgin() / 展开运算符{…obj} 拷贝对象 2.拷贝数组:Array.prototype.con…

开发中我们经常需要复制一个对象。如果直接用赋值会有下面问题:
在这里插入图片描述

8.1 浅拷贝

首先浅拷贝和深拷贝只针对引用类型
浅拷贝:拷贝的是地址
常见方法:
1.拷贝对象:Object.assgin() / 展开运算符{…obj} 拷贝对象
2.拷贝数组:Array.prototype.concat() 或者 […arr]
在这里插入图片描述
但是浅拷贝只适用于单层(简单数据类型,里面不要再套复杂数据类型)

【例如】
在这里插入图片描述
如果是简单数据类型拷贝值,引用数据类型拷贝的是地址(简单理解:如果是单层对象,没问题,如果有多层就有问题)

8.2 深拷贝

首先浅拷贝和深拷贝只针对引用类型
深拷贝:拷贝的是对象,不是地址
常见方法:
(1)通过递归实现深拷贝
(2)lodash / cloneDeep
(3)通过JSON.stringify()实现

一、通过递归实现深拷贝
函数递归:
如果一个函数在内部可以调用其本身,那么这个函数就是递归函数
在这里插入图片描述
●简单理解:函数内部自己调用自己,这个函数就是递归函数
●递归函数的作用和循环效果类似
●由于递归很容易发生"栈溢出”错误(stack overflow),所以必须要加退出条件return

【示例】

// 拷贝函数
function deepCopy(newObj, oldObj) {for (let k in oldObj) {// 处理数组的问题if (oldObj[k] instanceof Array) {newObj[k] = []// 递归调用 把数组里的值一个一个给deepCopy(newObj[k], oldObj[k])}// 处理对象问题else if (oldObj[k] instanceof Object) {newObj[k] = {}// 递归调用  deepCopy(newObj[k], oldObj[k])}else {// k 属性名  oldObj[k] 属性值newObj[k] = oldObj[k]}}
}

深拷贝总结:
1.要用到函数递归
2.当我们在普通拷贝时,直接赋值即可。但是如果遇到数组或者对象,就需要再次调用递归函数
3.记住先Array再Object (因为数组也属于对象)

二、js库lodash里面cloneDeep内部实现了深拷贝
【示例】

<body><!-- 先引用 --><script src="lodash.min.js"></script><script>const obj = {name: 'Kai',age: 18,hobby: ['羽毛球', '足球'],family: {sister: 'pink'}}// 语法:_.cloneDeep(要被克隆的对象)const o = _.cloneDeep(obj)o.family.sister = 'blue'o.age = 3console.log(o)console.log(obj)</script>
</body>

三、利用JSON实现深拷贝
【示例】

<body><script>const obj = {name: 'Kai',age: 18,hobby: ['羽毛球', '足球'],family: {sister: 'pink'}}// 把对象转换为JSON字符串// JSON.stringify(obj)const o = JSON.parse(JSON.stringify(obj))console.log(o)o.family.sister = '1234'console.log(obj)</script>
</body>

在这里插入图片描述

在这里插入图片描述

8.3 throw抛出异常

异常处理是指预估代码执行过程中可能发生的错误,然后最大程度的避免错误的发生导致整个程序无法继续运行
在这里插入图片描述
总结:
1.throw抛出异常信息,程序也会终止执行
2.throw后面跟的是错误提示信息
3.Error对象配合throw使用,能够设置更详细的错误信息

8.4 try/catch捕获错误信息

我们可以通过 try / catch 捕获错误信息(浏览器提供的错误信息)
try 试试catch 拦住finally 最后
在这里插入图片描述
总结:
1.try-catch用于捕获错误信息
2.将可能发生错误的代码写在try代码段中
3.如果try代码段中出现错误后,会执行catch代码段,并截获到错误信息
4. finally不管是否有错误,都会执行

8.5 debugger

使用方法:
在这里插入图片描述

http://www.tj-hxxt.cn/news/111111.html

相关文章:

  • 佛山html5网站建设搜资源
  • 网站 目录 结构seo标签怎么优化
  • 综合购物网站排名b2b免费发布网站大全
  • 网站ip和pv的比例精准营销及推广
  • 安阳官网网站快速排名推广百度指数工具
  • wordpress检索蜘蛛插件西安快速排名优化
  • 农业 网站源码世界疫情最新数据
  • 龙岩网站制作优化网站的公司哪家好
  • 泉州做 php 网站优化问题
  • 3d做号网站佛山网络推广平台
  • 西南交通建设集团股份有限公司网站厦门网站制作全程服务
  • 建设化工网站的目的济南网站优化
  • 成都最专业做网站的网站seo资讯
  • 平台推广销售话术厦门百度整站优化服务
  • 做pcb网站的公司谷歌三件套下载
  • 传媒公司网站设计方案宁德市安全教育平台
  • 北京做建筑信息的网站广告优化
  • wordpress做的网站效果超级软文
  • 外贸网站 流量发稿
  • 福建漳州网站建设费用西安seo网站推广优化
  • 黔东南州两学一做教育网站中级经济师考试
  • 淄博网站建设给力臻动传媒北京seo百度推广
  • 做衣服的网站百度在线咨询
  • wordpress引用js放到最后seo需要培训才能找到工作吗
  • 网站备案 99长沙网络推广哪家
  • 自己建网站做app今日热点新闻排行榜
  • 做免费采集电影网站犯法吗seo怎么做教程
  • 义乌专业做网站的seo网站分析
  • 龙岗微信网站制作百度推广后台登录首页
  • wordpress技术站主题免费seo工具大全