with语句

注意

with语句已被弃用。但基本上所有浏览器都还支持它。

为什么还要使用with语法?

我们在vue的template中写属性时,是无需指定对象this的,vue解析template的时候就用了with语法。

怎么使用的?

js 复制代码
const obj = {
  name: 'jason',
  age: 25
};

with (obj) {
  console.log(name, age);
}

with语法的作用

基本上,可以从上面例子可以看出with语法的作用。

官方的说明是:with语句扩展一个语句的作用域链。

描述

js查找某个未使用命名空间的变量时,会通过作用域链来查找,作用域链是跟执行代码的context或者包含这个变量的函数有关。

with语句将某个对象添加到作用域链的顶部,如果with语句中有某个未使用命名空间的变量,跟作用域链的某个属性同名,则这个变量指向这个属性值。

严格模式下无法使用

我们写vue代码,都是在严格模式下的,那么vue是如何在严格模式下执行with语句的呢?

结合Function()构造函数

可以通过new Function()创建函数,该函数仅在全局作用域中执行。

with语句放在new Function()创建的函数体中。

js 复制代码
const obj = {
  name: 'jason',
  age: 25
};
const fn = new Function(`
  with (obj) {
    console.log(name, age);
  }
`);
console.log(fn());

使用with语法的利弊

肯定是因为弊端更多,所以被废弃。

可以在不造成性能损失的情况下,减少变量的长度。造成的附加计算量很少。

  1. 使得程序在查找变量值时,都是先在指定的对象中查找。所以那些本来不是这个对象的属性的变量,查找起来会很慢。若是对性能要求较高的场合,with语句中的变量只应该包含这个指定对象的属性(同vue的template)。

  2. 不易阅读

js 复制代码
function f(x, o) {
  // 不能确定x是o的属性,还是入参x。
  with (o) print(x);
}
  1. 无法向前兼容
js 复制代码
// 若foo是一个数组,在es5环境下,数组是没有values属性的,所以with内部的values是入参values。
// rs6环境下,数组具有values属性,with内部的values指向数组的属性。
function f(foo, values) {
  with (foo) {
    console.log(values);
  }
}
相关推荐
周星星日记2 分钟前
vue中hash模式和history模式的区别
前端·面试
Light602 分钟前
Vue 高阶优化术:v-bind 与 v-on 的实战妙用与思维跃迁
前端·低代码·vue3·v-bind·组件封装·v-on·ai辅助开发
周星星日记3 分钟前
5.为什么vue中使用query可以保留参数
前端·vue.js
lebornjose3 分钟前
javascript - webgl中绑定(bind)缓冲区的逻辑是什么?
前端·webgl
瘦的可以下饭了8 分钟前
Day05- CSS 标准流、浮动、Flex布局
前端
前端无涯10 分钟前
React中setState后获取更新后值的完整解决方案
前端·react.js
西愚wo10 分钟前
前端开发者必备:在浏览器控制台批量提取HTML表单字段名(Label)
前端
小鸡吃米…37 分钟前
Python - 类属性
java·前端·python
前端不太难1 小时前
Navigation State 驱动的页面调试方法论
开发语言·前端·react.js
用户47949283569151 小时前
你每天都在用的 JSON.stringify ,V8 给它开了“加速通道”
前端·chrome·后端