js中的with了解一下
创始人
2024-11-11 05:09:37
0

官方提示:已弃用, 不再推荐使用该特性。
虽然一些浏览器仍然支持它,但也许已从相关的 web 标准中移除,也许正准备移除或出于兼容性而保留。

来了解一下为啥要弃用的理由:

语法: with(expression){…}

expression: 将给定的表达式添加到在评估语句时使用的作用域链上。with会创建一个新的作用域,

就是说,with 代码块内部,每个变量首先会指向 expression 对象属性,如果expression 对象上面没有这个属性,那么就会依次向上找,如果一直找不到,最终就会在顶层定义一个属性名的变量,这时候就会发生变量的泄漏

上代码演示吧:

function test(obj){     with(obj){         age = 100;     } } 

我们定义了一个函数,参数为一个对象,我们想通过with的形式给传入的obj对象修改age属性

let obj1 = { name: 'mike', age: 18} let obj2 = { name: 'lili' } 

我们分别定义了两个对象,一个包含age属性,另一个不包含age属性

下面我们来运行一下test方法吧

test(obj1) obj1 // {name: 'mike', age: 100} test(obj2) obj2 // {name: 'lili'} age // 100 

通过代码的执行,我们看到包含age属性的对象,通过with中的执行语句修改了对象的age属性,但是不包含age属性的对象,并没有修改

实际上with中的age = 100,开始的时候会找obj2上面时候有age属性,如果没有,他会往上面找,显然test方法中也没有这个age,那么就会再次往上找,直到全局作用域,还是没有,这时候就会新建一个age属性,然后赋值为100了
显然上面操作obj2的时候是有问题的,我们并不是要在全局新建一个age的属性,而且函数的数据也被泄漏到全局中了

所以,弃用是必须的

上一篇:HCIP笔记1

下一篇:100条超牛的DOS命令

相关内容

热门资讯

一分钟教你!Aapoker外挂... 一分钟教你!Aapoker外挂透明挂辅助脚本,太累了原来确切是有挂(2021已更新)(哔哩哔哩);是...
带你了解!(腾讯广东麻将)外挂... 带你了解!(腾讯广东麻将)外挂透明挂辅助插件(辅助挂)太嚣张了原来确实是有挂的(2020已更新)(哔...
玩家实测!nzt德州辅助软件(... 玩家实测!nzt德州辅助软件(wpk插件)软件透明挂,原来是真的有挂(2021已更新)(哔哩哔哩);...
总算了解!(Wepoke胜率)... 相信很多朋友都在电脑上玩过Wepoke胜率吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家...
2秒钟猫腻!全民牛牛提升胜率,... 2秒钟猫腻!全民牛牛提升胜率,太嚣张了原来是有挂的(2024已更新)(哔哩哔哩)是一款可以让一直输的...
一起来探讨!(wpkplus)... 一起来探讨!(wpkplus)原来是真的有挂!(辅助挂)其实真的是有挂(2022已更新)(哔哩哔哩)...
一分钟了解!微扑克中牌率(We... 一分钟了解!微扑克中牌率(Wepoke下载)软件透明挂,其实一直确实是有挂(2024已更新)(哔哩哔...
热门推荐!(友乐广西麻将)外挂... 《友乐广西麻将软件透明挂》是一款多人竞技的友乐广西麻将辅助透视游戏,你将微扑克对手来到同一个战场,为...
如何分辨真伪!Ruuner外挂... 自定义新版Ruuner系统规律,只需要输入自己想要的开挂功能,一键便可以生成出Ruuner专用辅助器...
盘点十款!(wepoke脚本)... 盘点十款!(wepoke脚本)外挂透视辅助器开挂!(透视)原来是真的有挂(2022已更新)(哔哩哔哩...