75 lines
1.8 KiB
Markdown
75 lines
1.8 KiB
Markdown
---
|
||
title: With
|
||
localeTitle: 同
|
||
---
|
||
## 同
|
||
|
||
JavaScript的`with`语句是在一个对象上编辑多个属性的简便方法。大多数开发人员不鼓励使用`with` ,您最好不要使用此关键字。
|
||
|
||
**注意** : `"strict mode"`禁止使用`with` 。
|
||
|
||
### 句法
|
||
|
||
```syntax
|
||
with (expression)
|
||
statement
|
||
```
|
||
|
||
### 示例用法
|
||
|
||
在JavaScript中,您可以单独修改对象的属性,如下所示:
|
||
|
||
```javascript
|
||
let earth = {};
|
||
earth.moons = 1;
|
||
earth.continents = 7;
|
||
```
|
||
|
||
`with`为您提供了修改对象属性的简写:
|
||
|
||
```javascript
|
||
with (earth) {
|
||
moons = 1;
|
||
continents = 7;
|
||
}
|
||
```
|
||
|
||
虽然这个例子很做作,你能理解的用例`with`更多,如果你有更大的物体象下面这样:
|
||
|
||
```javascript
|
||
earth.continents.australia.geography.ocean = "Pacific";
|
||
earth.continents.australia.geography.river = "Murray";
|
||
earth.continents.australia.geography.mountain = "Kosciuszko";
|
||
```
|
||
|
||
### 备择方案
|
||
|
||
你不应该使用它`with`因为它有微妙的错误和兼容性问题。强烈推荐的方法是将对象分配给变量,然后修改变量的属性。以下是使用更大对象的示例:
|
||
|
||
```javascript
|
||
let earth = {
|
||
continents: {
|
||
australia: {
|
||
geography: {}
|
||
}
|
||
}
|
||
};
|
||
|
||
let geo = earth.continents.australia.geography;
|
||
|
||
geo.ocean = "Pacific";
|
||
geo.river = "Murray";
|
||
geo.mountain = "Kosciuszko";
|
||
```
|
||
|
||
### 试试看
|
||
|
||
https://repl.it/Mixg/5
|
||
|
||
#### 更多信息:
|
||
|
||
[https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/with](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/with)
|
||
|
||
[https://yuiblog.com/blog/2006/04/11/with-statement-considered-harmful/](https://yuiblog.com/blog/2006/04/11/with-statement-considered-harmful/)
|
||
|
||
[http://2ality.com/2011/06/with-statement.html](http://2ality.com/2011/06/with-statement.html) |