理解javascript中的with关键字

yizhihongxing

当我们在使用JS进行开发时,可能会遇到使用with关键字的代码。with可以被用来打破常规的JS作用域规则,允许我们更方便地访问某些对象中的属性和方法。然而,with关键字在使用上很容易出错,也容易导致代码不易阅读和维护。因此,在使用with语句时,需要谨慎使用,遵循一些约定和最佳实践,下面将详细讲解“理解JavaScript中的with关键字”,帮助读者更好地理解with语句。

什么是With语句

在JavaScript中,with语句是一种让你在多次访问同一个对象的时候,可以省略对象名进行访问的方式。

一般语法如下:

with (expression) statement

例如:

var obj = {num:42};
with(obj) {
    console.log(num); // 42
}

With语句的用法

JavaScript的with语句可以让你在多次访问同一个对象的时候,可以省略对象名进行访问的方式,这无疑带来了一定的便利。 然而,使用with语句不仅会降低代码的可读性、可调试性,而且还可能造成性能上的问题,并且有安全漏洞,因此在实际应用中,我们应该尽量避免使用它。

with语句当中expression所返回的对象,会被绑定到with语句体内的一个新变量当中。我们随后就可以通过省略对象名,直接调用这个对象内的所有方法和属性了。

例如:

var obj = {num: 42};

with (obj){
    console.log(num); // 42
}

通过上面的代码,我们可以看到,with语句中的obj对象被绑定到了num变量上,并且可以直接访问到num属性。

With语句的缺点

虽然with语句可能使编码更容易,但它也有很多缺点:

  1. 可读性差:代码在使用 with语句时变得混乱。代码没有清晰地表达出操作的对象,尤其是钩子代码和回调函数,会被嵌入到 with 上下文中,使其难以确定。

  2. 性能问题:with 语句会使 JavaScript 引擎难以优化代码,从而导致程序运行缓慢。如果应用程序需要处理许多对象,那么大量使用 with 语句会增加资源消耗的可能性。

  3. 安全问题:with语句存在安全漏洞,使用with语句,就意味着你信任数值传递到with语句中的属性名称,如果传递了一个恶意对象而不是可预料的对象,攻击者可能可以定义有害行为,并可能比使用显式对象引用错误更难发现和诊断这些行为。

因此,我们不建议使用 with 语句,相反请使用显式对象引用,例如:

var obj = {num: 42};

console.log(obj.num); // 42

不要使用 With 语句的情况。

一般来说,我们不建议使用 with 语句,下面是使用 with 的情况列表:

  1. 速度

如果您的 JavaScript 程序需要处理许多对象,则大量使用 with 语句会增加资源消耗的可能性,因此会导致程序运行缓慢。

  1. 可读性

代码在使用 with 语句时变得混乱。如果您使用回调,将难以判断回调的目标对象。

  1. 安全

如果编写不可预测的代码,with 语句会导致 JavaScript 漏洞。

为了弥补 with 语句 带来的缺点,可以使用立即执行函数(Immediately Invoked Function Expressions, IIFEs),也就是JavaScript中的自执行函数:

var obj = {num: 42};

(function(obj){
    console.log(obj.num); // 42
})(obj);

在以上代码中,我们使用了自执行函数并将obj作为它的参数传递进去,这样就避免了with语句的缺点。

示例1:

  var book = {
    "name": "《JavaScript高级程序设计》",
    "author": "尼古拉斯·C.萨卡斯",
    "publishTime": "2013年3月6日",
    "price": 89.00
  };

with(book) {
    console.log("书名 = ", name);
    console.log("作者 = " , author);
    console.log("发布时间 = ",publishTime);
    console.log("价格 = ", price);
}

代码执行效果如下:

书名 = 《JavaScript高级程序设计》
作者 =  尼古拉斯·C.萨卡斯
发布时间 =  2013年3月6日
价格 =  89

示例2:

var x = 1, y = 2;

with({x: 3, y: 4}){
    console.log(x + y);  // 7
    console.log(x - y);  // -1
}

代码执行效果如下:

7
-1

因为我们在with语句中传入了一个新的对象,这个新对象属性值和原先的变量名是一样的,但是结果不一样,从这里我们可以看出,代码中的x和y示例,是有时候不一定会指向全局变量。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:理解javascript中的with关键字 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • javascript 循环读取JSON数据的代码

    让我来为大家详细讲解“javascript 循环读取JSON数据的代码”的完整攻略。 什么是JSON JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成。JSON数据格式可以表示数字、字符串、布尔值、对象、数组等类型的数据,用于存储和交换数据。 如何读取JSON数据 读取JSO…

    JavaScript 2023年5月27日
    00
  • js清空form表单中的内容示例

    下面是详细讲解 “js清空form表单中的内容示例” 的完整攻略。 1. 使用原生 JavaScript 清空表单的内容 使用原生 JavaScript 可以很轻松地清空表单的内容。下面是清空一个 id 为 “form1” 的表单中所有的输入框的值: document.getElementById("form1").reset(); 上述…

    JavaScript 2023年6月10日
    00
  • jQuery焦点图切换简易插件制作过程全纪录

    下面我将详细讲解“jQuery焦点图切换简易插件制作过程全纪录”。 一、前言 做一个好用的网站,除了有好的设计外,交互效果和动画效果会让用户的体验更好。当我们需要制作焦点图时,可以选择使用第三方的插件。但为了更好地理解焦点图的制作原理,我们可以自己来手写一个简易焦点图切换插件。 二、需求分析 在开始编码之前,我们需要考虑一下插件的需求: 可以实现无缝轮播焦点…

    JavaScript 2023年6月11日
    00
  • UpdatePanel触发javascript脚本的方法附代码

    关于”UpdatePanel触发javascript脚本的方法”,我来详细讲解一下。 首先,我们需要了解一下UpdatePanel是什么。UpdatePanel在ASP.NET中是一个用来局部刷新页面的控件。当UpdatePanel中的内容需要更新时,ASP.NET会自动发送异步请求并更新指定部分的内容。而JavaScript脚本则是一种脚本语言,可以用来为…

    JavaScript 2023年6月10日
    00
  • js中的鼠标事件有哪些(用法示例学习进阶)

    JS中的鼠标事件是指在浏览器中用户和鼠标交互时,所触发的事件。在前端开发中,这些鼠标事件被广泛应用于各种网站和应用程序中。下面将介绍一些常用的鼠标事件以及它们的用法示例。 鼠标单击事件(click) 鼠标单击事件(click)是指在鼠标左键单击时所触发的事件。在页面中使用最为广泛的是按钮的单击事件。下面是一个示例,当按钮被单击时,将弹出一个提示框。 <…

    JavaScript 2023年6月11日
    00
  • javascript Error 对象 错误处理

    下面是关于“JavaScript Error 对象错误处理”的完整攻略: 定义 JavaScript Error 对象是一个构造函数,用于创建表示错误情况的对象。 Error 对象可以在发生异常、错误或任何其他意外情况时使用,从而方便地对错误进行处理和调试。 创建一个 Error 对象 我们可以使用 new 关键字创建一个 Error 对象,如下所示: le…

    JavaScript 2023年6月10日
    00
  • JS实现json对象数组按对象属性排序操作示例

    讲解“JS实现json对象数组按对象属性排序操作示例”的完整攻略,大致分为以下步骤: 1.准备JSON对象数组数据首先,我们需要准备一组JSON对象数组数据。例如,假设我们要对一个用户列表进行排序,我们可以定义一个包含多个用户信息的数组,每个用户信息都是一个JSON对象。示例代码如下: var users = [ { name: "张三"…

    JavaScript 2023年5月27日
    00
  • 详解JavaScript对象转原始值

    回答: 1. JavaScript对象转原始值 在JavaScript中,当一个对象被转换成原始类型时,会调用该对象的valueOf()和toString()方法。如果这两个方法都不存在或没有返回原始值,则会抛出TypeError异常。 1.1 valueOf()方法 对于大多数JavaScript对象,valueOf()方法会返回对象本身。但是对于包装对象…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部