ๆญค้ ้ข็”ฑ็คพ็พคๅพž่‹ฑๆ–‡็ฟป่ญฏ่€Œไพ†ใ€‚ไบ†่งฃๆ›ดๅคšไธฆๅŠ ๅ…ฅ MDN Web Docs ็คพ็พคใ€‚

View in English Always switch to English

JavaScript ็š„่ณ‡ๆ–™ๅž‹ๅˆฅ่ˆ‡่ณ‡ๆ–™็ตๆง‹

็จ‹ๅผ่ชž่จ€้ƒฝๅ…ทๆœ‰่ณ‡ๆ–™็ตๆง‹๏ผŒไฝ†ๅœจไธๅŒ็š„็จ‹ๅผ่ชž่จ€ไน‹้–“ๆœƒๆœ‰ไบ›ๅทฎ็•ฐใ€‚้€™่ฃกๅฐ‡ๅˆ—ๅ‡บๅฏไปฅๅœจ JavaScript ไธญไฝฟ็”จ็š„่ณ‡ๆ–™็ตๆง‹๏ผŒไปฅๅŠๅฎƒๅ€‘็š„็‰นๆ€ง๏ผ›ๅฎƒๅ€‘ๅฏไปฅ็”จไพ†ๆง‹ๆˆๅ…ถไป–็š„่ณ‡ๆ–™็ตๆง‹ใ€‚ๅฆ‚ๆžœๅฏไปฅ็š„่ฉฑ๏ผŒๆœƒๆจ™็คบ่ˆ‡ๅ…ถไป–่ชž่จ€ไธๅŒ็š„ๅœฐๆ–นใ€‚

ๅ‹•ๆ…‹ๅž‹ๅˆฅ

JavaScript ๆ˜ฏๅผฑๅž‹ๅˆฅ๏ผŒไนŸ่ƒฝ่ชชๆ˜ฏๅ‹•ๆ…‹็š„็จ‹ๅผ่ชž่จ€ใ€‚้€™ไปฃ่กจไฝ ไธๅฟ…็‰นๅˆฅๅฎฃๅ‘Š่ฎŠๆ•ธ็š„ๅž‹ๅˆฅใ€‚็จ‹ๅผๅœจ้‹ไฝœๆ™‚๏ผŒๅž‹ๅˆฅๆœƒ่‡ชๅ‹•่ฝ‰ๆ›ใ€‚้€™ไนŸไปฃ่กจไฝ ๅฏไปฅไปฅไธๅŒ็š„ๅž‹ๅˆฅไฝฟ็”จๅŒไธ€ๅ€‹่ฎŠๆ•ธใ€‚

js
var foo = 42; // foo ็›ฎๅ‰ๆ˜ฏๆ•ธๅญ—
var foo = "bar"; // foo ็›ฎๅ‰ๆ˜ฏๅญ—ไธฒ
var foo = true; // foo ็›ฎๅ‰ๆ˜ฏๅธƒๆž—ๅ€ผ

่ณ‡ๆ–™ๅž‹ๅˆฅ

ๆœ€ๆ–ฐ็š„ ECMAScript ๆจ™ๆบ–ๅฎš็พฉไบ†ไธƒ็จฎ่ณ‡ๆ–™ๅž‹ๅˆฅ๏ผš

ๅŽŸๅง‹ๅ€ผ

้™คไบ†็‰ฉไปถไปฅๅค–็š„ๆ‰€ๆœ‰ๅ€ผ๏ผŒ้ƒฝๆ˜ฏๅŽŸๅง‹ๅฎš็พฉ็š„ๅ€ผ๏ผˆๅ€ผๆ„ๅ‘ณ่‘—ไธ่ƒฝ่ขซๆ”น่ฎŠ๏ผ‰ใ€‚ไพ‹ๅฆ‚่ˆ‡ C ไธๅŒ็š„ๅœฐๆ–น๏ผŒๅฐฑๆ˜ฏๅญ—ไธฒๆ˜ฏไธ่ฎŠ็š„ใ€‚ๆˆ‘ๅ€‘ๅผ•็”จ้€™ไบ›้กžๅž‹็š„ๅ€ผ็‚บ primitive values๏ผˆๅŽŸๅง‹ๅ€ผ๏ผ‰ใ€‚

ๅธƒๆž—ๅž‹ๅˆฅ

ๅธƒๆž—๏ผˆBoolean๏ผ‰ไปฃ่กจไบ†ๆœ‰ๅ…ฉๅ€‹ๅ€ผ็š„้‚่ผฏๅฏฆ้ซ”๏ผštrue ่ˆ‡ falseใ€‚

Null ๅž‹ๅˆฅ

Null ๅž‹ๅˆฅๅชๆœ‰ไธ€ๅ€‹ๅ€ผ๏ผšnullใ€‚่ซ‹ๅƒ่ฆ‹ null ่ˆ‡ Nullใ€‚

ๆœชๅฎš็พฉๅž‹ๅˆฅ

ไธ€ๅ€‹ๆฒ’ๆœ‰่ขซๅฎš็พฉ็š„่ฎŠๆ•ธๆœ‰ undefined ๅ€ผใ€‚่ซ‹ๅƒ่ฆ‹ undefined ่ˆ‡ Undefinedใ€‚

ๆ•ธๅญ—ๅž‹ๅˆฅ

ๆ นๆ“š ECMAScript ๆจ™ๆบ–๏ผŒๆ•ธๅญ—ๅž‹ๅˆฅๅชๆœ‰ไธ€็จฎ๏ผš้›™็ฒพๅบฆ 64 ไฝๅ…ƒไบŒ้€ฒๅˆถๆ ผๅผ IEEE 754 ๅ€ผ๏ผˆๅœจ -(2^53 -1) and 2^53 -1 ไน‹้–“็š„ๆ•ธๅญ—๏ผ‰ใ€‚่€Œๆ•ดๆ•ธไธฆๆฒ’ๆœ‰ๆŒ‡ๅฎš็š„ๅž‹ๅˆฅใ€‚ๆ•ธๅญ—้™คไบ†่ƒฝไปฃ่กจๆตฎ้ปžๆ•ธไปฅๅค–๏ผŒ้‚„ๆœ‰ไธ‰ๅ€‹็ฌฆ่™Ÿๅ€ผ๏ผš+Infinityใ€-Infinityใ€NaN๏ผˆnot-a-number๏ผŒ้žๆ•ธๅญ—๏ผ‰ใ€‚

่ฆๆชขๆŸฅๅœจ +/-Infinity ๅ…งๅฏ็”จ็š„ๆœ€ๅคงๅ€ผๆˆ–ๆœ€ๅฐๅ€ผ๏ผŒๅฏไปฅ็”จ Number.MAX_VALUE ๆˆ– Number.MIN_VALUE ๅธธๆ•ธใ€‚ๅพž ECMAScript 6 ้–‹ๅง‹๏ผŒไนŸๅฏไปฅ้€้Ž Number.isSafeInteger()ใ€Number.MAX_SAFE_INTEGERใ€Number.MIN_SAFE_INTEGER ๆชขๆŸฅๆŸๆ•ธๅญ—ๆ˜ฏๅฆ็‚บ้›™็ฒพๅบฆๆตฎ้ปžๅ€ผไน‹้–“ใ€‚Beyond this range, integers in JavaScript are not safe anymore and will be a double-precision floating point approximation of the value.

The number type has only one integer that has two representations: 0 is represented as -0 and +0. ("0" is an alias for +0). In the praxis, this has almost no impact. For example +0 === -0 is true. However, you are able to notice this when you divide by zero:

js
> 42 / +0
Infinity
> 42 / -0
-Infinity

Although a number often represents only its value, JavaScript provides some binary operators. These can be used to represent several Boolean values within a single number using bit masking. However, this is usually considered a bad practice, since JavaScript offers other means to represent a set of Booleans (like an array of Booleans or an object with Boolean values assigned to named properties). Bit masking also tends to make code more difficult to read, understand, and maintain. It may be necessary to use such techniques in very constrained environments, like when trying to cope with the storage limitation of local storage or in extreme cases when each bit over the network counts. This technique should only be considered when it is the last measure that can be taken to optimize size.

ๅญ—ไธฒๅž‹ๅˆฅ

JavaScript ็š„ ๅญ—ไธฒๅž‹ๅˆฅ็”จไพ†ไปฃ่กจๆ–‡ๅญ—่ณ‡ๆ–™ใ€‚ๅฎƒๆ˜ฏไธ€็ต„ 16 ไฝ็š„ๆœชๅฎฃๅ‘Šใ€Œๅ…ƒ็ด ใ€ๅ€ผใ€‚ๆฏๅ€‹ๅญ—ไธฒ็š„ๅ…ƒ็ด ๏ผŒๅœจๅญ—ไธฒๅ…ง็š†ไฝ”ๆœ‰ไธ€ไฝใ€‚็ฌฌไธ€ๅ€‹ๅ…ƒ็ด ไฝๆ–ผ็ดขๅผ•็š„็ฌฌ 0 ไฝ๏ผŒไธ‹ไธ€ๅ€‹ๅ…ƒ็ด ไฝๆ–ผ็ฌฌ 1 ไฝ๏ผŒไธฆไพๆญค้กžๆŽจใ€‚ๅญ—ไธฒ็š„้•ทๅบฆ๏ผŒๆ˜ฏๆŒ‡่ฉฒๅญ—ไธฒๆœ‰ๅคšๅฐ‘ๅ…ƒ็ด ใ€‚

่ˆ‡ C ้€™้กž็š„่ชž่จ€ไธๅŒ๏ผŒJavaScript ๅญ—ไธฒๆ˜ฏไธ่ฎŠ็š„๏ผŒๆ„ๆ€ๆ˜ฏ่ชช็•ถๅญ—ไธฒ่ขซๅ‰ต้€ ๅ‡บไพ†ไปฅๅพŒ๏ผŒไฝ ไธๅฏ่ƒฝไฟฎๆ”นๅฎƒใ€‚ไธ้Ž๏ผŒๅฏไปฅๅŸบๆ–ผๆ“ไฝœๅŽŸไพ†็š„ๅญ—ไธฒ๏ผŒไพ†็”ข็”Ÿๆ–ฐ็š„ๅญ—ไธฒใ€‚ไพ‹ๅฆ‚๏ผš

  • ้€้ŽๆŒ‘้ธๅ–ฎๅ€‹ๅญ—ๆฏๆˆ–ไฝฟ็”จ String.substr() ็š„ๅŽŸๅง‹ๅญๅญ—ไธฒใ€‚
  • ไฝฟ็”จ็ดš่ฏ้‹็ฎ—็ฌฆ๏ผˆ+๏ผ‰ๆˆ– String.concat() ้€ฃๆŽฅๅ…ฉๅ€‹ๅญ—็ฌฆไธฒใ€‚

Beware of "stringly-typing" your code!

It can be tempting to use strings to represent complex data. Doing this comes with short-term benefits:

  • It is easy to build complex strings with concatenation.
  • Strings are easy to debug (what you see printed is always what is in the string).
  • Strings are the common denominator of a lot of APIs (input fields, local storage values, XMLHttpRequest responses when using responseText, etc.) and it can be tempting to only work with strings.

With conventions, it is possible to represent any data structure in a string. This does not make it a good idea. For instance, with a separator, one could emulate a list (while a JavaScript array would be more suitable). Unfortunately, when the separator is used in one of the "list" elements, then, the list is broken. An escape character can be chosen, etc. All of this requires conventions and creates an unnecessary maintenance burden.

Use strings for textual data. When representing complex data, parse strings and use the appropriate abstraction.

Symbol type

Symbols are new to JavaScript in ECMAScript Edition 6. A Symbol is a unique and immutable primitive value and may be used as the key of an Object property (see below). In some programming languages, Symbols are called atoms. You can also compare them to named enumerations (enum) in C. For more details see Symbol and the Symbol object wrapper in JavaScript.

Objects

ไปฅ่ณ‡่จŠ็ง‘ๅญธ่€Œ่จ€๏ผŒ็‰ฉไปถๆ˜ฏๅ€‹่ƒฝ้€้Židentifierๅƒ็…ง็š„ๆœ‰ๆ•ธๅ€ผ่จ˜ๆ†ถ้ซ”ใ€‚

Properties

In JavaScript, objects can be seen as a collection of properties. With the object literal syntax, a limited set of properties are initialized; then properties can be added and removed. Property values can be values of any type, including other objects, which enables building complex data structures. Properties are identified using key values. A key value is either a String or a Symbol value.

There are two types of object properties which have certain attributes: The data property and the accessor property.

Data property

Associates a key with a value and has the following attributes:

Attribute Type Description Default value
[[Value]] Any JavaScript type The value retrieved by a get access of the property. undefined
[[Writable]] Boolean If false, the property's [[Value]] can't be changed. false
[[Enumerable]] Boolean If true, the property will be enumerated in for...in loops. See also Enumerability and ownership of properties false
[[Configurable]] Boolean If false, the property can't be deleted and attributes other than [[Value]] and [[Writable]] can't be changed. false
Attribute Type Description
Read-only Boolean Reversed state of the ES5 [[Writable]] attribute.
DontEnum Boolean Reversed state of the ES5 [[Enumerable]] attribute.
DontDelete Boolean Reversed state of the ES5 [[Configurable]] attribute.

Accessor property

Associates a key with one or two accessor functions (get and set) to retrieve or store a value and has the following attributes:

Attribute Type Description Default value
[[Get]] Function object or undefined The function is called with an empty argument list and retrieves the property value whenever a get access to the value is performed. See also get. undefined
[[Set]] Function object or undefined The function is called with an argument that contains the assigned value and is executed whenever a specified property is attempted to be changed. See also set. undefined
[[Enumerable]] Boolean If true, the property will be enumerated in for...in loops. false
[[Configurable]] Boolean If false, the property can't be deleted and can't be changed to a data property. false

ๅ‚™่จป๏ผš Attribute is usually used by JavaScript engine, so you can't directly access it(see more about Object.defineProperty()).That's why the attribute is put in double square brackets instead of single.

"Normal" objects, and functions

A JavaScript object is a mapping between keys and values. Keys are strings (or Symbols) and values can be anything. This makes objects a natural fit for hashmaps.

Functions are regular objects with the additional capability of being callable.

Dates

When representing dates, the best choice is to use the built-in Date utility in JavaScript.

Indexed collections: Arrays and typed Arrays

Arrays are regular objects for which there is a particular relationship between integer-keyed properties and the length property.

Additionally, arrays inherit from Array.prototype, which provides a handful of convenient methods to manipulate arrays. For example, indexOf() searches a value in the array and push() appends an element to the array. This makes Arrays a perfect candidate to represent ordered lists.

Typed Arrays present an array-like view of an underlying binary data buffer, and offer many methods that have similar semantics to the array counterparts. "Typed array" is an umbrella term for a range of data structures, including Int8Array, Float32Array, etc. Check the typed array page for more information. Typed arrays are often used in conjunction with ArrayBuffer and DataView.

Keyed collections: Maps, Sets, WeakMaps, WeakSets

These data structures take object references as keys and are introduced in ECMAScript Edition 6. Set and WeakSet represent a set of objects, while Map and WeakMap associate a value to an object. The difference between Maps and WeakMaps is that in the former, object keys can be enumerated over. This allows garbage collection optimizations in the latter case.

One could implement Maps and Sets in pure ECMAScript 5. However, since objects cannot be compared (in the sense of "less than" for instance), look-up performance would necessarily be linear. Native implementations of them (including WeakMaps) can have look-up performance that is approximately logarithmic to constant time.

Usually, to bind data to a DOM node, one could set properties directly on the object or use data-* attributes. This has the downside that the data is available to any script running in the same context. Maps and WeakMaps make it easy to privately bind data to an object.

Structured data: JSON

JSON (JavaScript Object Notation) is a lightweight data-interchange format, derived from JavaScript but used by many programming languages. JSON builds universal data structures. See JSON and JSON for more details.

More objects in the standard library

JavaScript has a standard library of built-in objects. Please have a look at the reference to find out about more objects.

ไฝฟ็”จ typeof ้‹็ฎ—ๅญไพ†ๅˆคๆ–ทๅž‹ๅˆฅ

typeof ้‹็ฎ—ๅญๅฏไปฅๅนซๅŠฉไฝ ๆ‰พๅˆฐไฝ ็š„่ฎŠๆ•ธๅž‹ๅˆฅ๏ผŒ่ซ‹้–ฑ่ฎ€ใ€ˆreference page ใ€‰ไพ†ๅ–ๅพ—ๆ›ดๅคš็ดฐ็ฏ€ๅŠ้‚Š็ทฃๆกˆไพ‹ใ€‚

See also