ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript でよくある落とし穴を回避する方法に関するヒントとテクニックの概要

JavaScript でよくある落とし穴を回避する方法に関するヒントとテクニックの概要

伊谢尔伦
伊谢尔伦オリジナル
2017-07-26 13:54:511076ブラウズ

1. 配列要素を並べ替えてみましたか?

JavaScript はデフォルトで英数字の順序を使用します。したがって、[1,2,5,10].sort() の結果は [1, 10, 2, 5] になります。

正しく並べ替えたい場合は、次のようにする必要があります: [1,2,5,10].sort((a, b) => a - b)

2 new Date() は非常に使いやすいです。

new Date() は次のものを受け取ることができます:

  • - パラメータを受け取りません: 現在の時刻を返します;

  • - パラメータ `x` を受け取ります: 1970 年 1 月 1 日 + `x` ミリ秒の値を返します。

  • - `new Date(1, 1, 1)` は 1901 年 2 月 1 日を返します。

  • - ただし....、「new Date(2016, 1, 1)」は 2016 を 1900 に加算するのではなく、単に 2016 を意味します。

3. 置換機能は本当に置換されませんか?

let s = "bob"
const replaced = s.replace('b', 'l')
replaced === "lob" // 只会替换掉第一个b
s === "bob" // 并且s的值不会变

すべての b を置き換える場合は、正規表現を使用します:

"bob".replace(/b/g, 'l') === 'lol'

4. [1,2,3] と [1,2,3] は要素が異なる 2 つの異なる配列であるため、比較演算には注意してください

// 这些可以
'abc' === 'abc' // true
1 === 1 // true
// 然而这些不行
[1,2,3] === [1,2,3] // false
{a: 1} === {a: 1} // false
{} === {} // false

たまたま同じだというだけ。したがって、単純に「===」だけで判断することはできません。

5. 配列は基本型ではありません

typeof {} === 'object' // true
typeof 'a' === 'string' // true
typeof 1 === number // true
// 但是....
typeof [] === 'object' // true

変数 `var` が配列であるかどうかを判断したい場合は、`Array.isArray(var)` を使用する必要があります。 `Array.isArray(var)`

6. 闭包

这是一个经典的JavaScript面试题:

const Greeters = []
for (var i = 0 ; i < 10 ; i++) {
 Greeters.push(function () { return console.log(i) })
}
Greeters[0]() // 10
Greeters[1]() // 10
Greeters[2]() // 10

虽然期望输出0,1,2,...,然而实际上却不会。知道如何Debug嘛?

有两种方法:

  • - 使用`let`而不是`var`。 

  • - 使用`bind`函数。

Greeters.push(console.log.bind(null, i))

当然,还有很多解法。这两种是我最喜欢的!

7. 关于bind

下面这段代码会输出什么结果?

class Foo {
 constructor (name) {
 this.name = name
 }
 greet () {
 console.log(&#39;hello, this is &#39;, this.name)
 }
 someThingAsync () {
 return Promise.resolve()
 }
 asyncGreet () {
 this.someThingAsync()
 .then(this.greet)
 }
}
new Foo(&#39;dog&#39;).asyncGreet()

如果你说程序会崩溃,并且报错:Cannot read property 'name' of undefined

因为第16行的`geet`没有在正确的环境下执行。当然,也有很多方法解决这个BUG!

- 喜欢使用`bind`函数来解决问题:

asyncGreet () {
 this.someThingAsync()
 .then(this.greet.bind(this))
}

这样会确保`greet`会被Foo的实例调用,而不是局部的函数的`this`。

- 如果你想要`greet`永远不会绑定到错误的作用域,你可以在构造函数里面使用`bind`来绑定。

class Foo {
 constructor (name) {
 this.name = name
 this.greet = this.greet.bind(this)
 }
}

- 你也可以使用箭头函数(=>)来防止作用域被修改。 

asyncGreet () {
 this.someThingAsync()
 .then(() => {
 this.greet()
 })
}

8. Math.min()比Math.max()大

Math.min() < Math.max() // false

因为Math.min() 返回 Infinity, 而 Math.max()

🎜6. 終わり🎜🎜これは JavaScript の典型的なインタビューの質問です: 🎜rrreee🎜 0、1、2、... が出力されることが期待されていますが、実際には出力されません。デバッグ方法を知っていますか? 🎜🎜方法は 2 つあります: 🎜🎜🎜🎜 - `var` の代わりに `let` を使用します。 🎜🎜🎜🎜 - `bind` 関数を使用します。 🎜🎜🎜rrreee🎜 もちろん、解決策はたくさんあります。この二人が私のお気に入りです! 🎜🎜🎜7.バインドについて🎜🎜次のコードはどのような結果を出力しますか? 🎜rrreee🎜 プログラムがクラッシュし、次のエラーが報告されると言う場合: 未定義のプロパティ 'name' を読み取れません。 🎜🎜🎜16行目の「geet」が正しい環境で実行されていないためです。もちろん、このバグを解決する方法はたくさんあります。 🎜🎜- 問題を解決するには `bind` 関数を使用するのが好きです: 🎜rrreee🎜これにより、ローカル関数 `this` ではなく、Foo のインスタンスから `greet` が確実に呼び出されます。 🎜🎜🎜 - 「greet」が間違ったスコープにバインドされないようにしたい場合は、コンストラクター内で「bind」を使用できます。 🎜rrreee🎜 - 矢印関数 (=>) を使用して、スコープが変更されないようにすることもできます。 🎜rrreee🎜8. Math.min() は Math.max() より大きいです🎜rrreee🎜 Math.min() は Infinity を返すのに対し、Math.max() は-Infinity を返します。 🎜

以上がJavaScript でよくある落とし穴を回避する方法に関するヒントとテクニックの概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。