ホームページ  >  記事  >  ウェブフロントエンド  >  JSタイマーの実装方法

JSタイマーの実装方法

一个新手
一个新手オリジナル
2017-10-06 10:42:482987ブラウズ

JS タイマー パラメーター分析と実際の質問

HTML5 Academy-Coder: タイマーの最初のパラメーターには、関数名、匿名関数、JS コード文字列、およびいくつかのインタビューの質問など、いくつかの異なる記述方法が含まれています。 「関数呼び出し」を書いています。

それでは、これらのさまざまな書き方は何を意味するのでしょうか?タイマーに表示される最初のパラメーター。スコープはどこに作成されますか?

タイマーの最初のパラメータ

関数名の書き方

これは、一定のミリ秒後に、この関数名の関数が実行キューに追加されることを意味します。それは実行します。

JSタイマーの実装方法

String形式の書き方

関数にパラメータがある場合、この呼び出し方法を使う人が多いでしょう。

JSタイマーの実装方法

setTimeout と setInterval はどちらも (最初のパラメータとして) 文字列を受け入れることができますが、この書き方は推奨されません。その理由は、コードを実行できるようにするために、コードの実行時に文字列が eval メソッドを通じて変換されるためです。

eval メソッド、その機能は文字列を JS として実行することです。 eval は多くの問題を解決でき、大きな効果がありますが、パフォーマンスの問題、セキュリティの問題、JS 厳密モードと非厳密モードの違いについて広く批判されています。

これらの欠点のため、多くの開発者はプロジェクトやコードでの使用を避けようとしています。

匿名関数の書き方

関数に引数を渡しても文字列を書く方法が使えない場合には、無名関数の書き方が便利です。

JSタイマーの実装方法

関数呼び出しの書き方

この書き方自体が間違っており、実際の開発ではほぼ不可能です。もちろん、インタビューで「落とし穴」として現れることもあります...

JSタイマーの実装方法

ここでの最初の関数は、コードのタイマー行が実行されるとすぐに実行され、返されるのは h5course 関数の戻り値です、関数自体ではなく。関数がデフォルトの戻り値 unknown を返した場合、setInterval はエラーを報告しません。

最初のパラメータのスコープ所有権

タイマーの最初のパラメータはグローバルスコープで実行されるため、関数内の「this」はこのグローバルオブジェクトを指します

JSタイマーの実装方法

演算結果はtrueです

JSタイマーの実装方法

実行結果は真実です

タイマーを使って実際の面接の質問で練習しましょう

各プリントアウトの結果は何ですか?

JSタイマーの実装方法

ヒント: 記事の下部にある答えを参照してください

方法「codesmith」という単語が表示されるまでに時間がかかりますか?

JSタイマーの実装方法

ヒント: 答えは記事の最後にあります

次のコードがどのように実行されるかを教えてください

JSタイマーの実装方法

ヒント:答えは記事の最後にあります

一言で言えば

実行する関数にパラメータがない場合は、関数名を使用して直接呼び出すことができます

パラメータを関数に渡す必要がある場合コールバック関数を使用する場合は、文字列をパラメータとして使用せず、匿名関数をパラメータとして使用し、匿名関数内でコールバック関数を実行します。

関数はグローバル スコープで実行されます

実際の面接の 3 つの質問への回答

最初の質問: 最初に 10 を出力し、約 1 秒後に 10 の 10 を同時に出力します。

2 番目の質問: 約 1000 ミリ秒 (約 1 秒)

3 番目の質問: 関数が実行されると、2 つの li の背景色がすぐに赤に設定され、約 5000 ミリ秒後にコンソールがエラーを報告します (2 つのエラー)。 )、エラー内容は「赤が定義されていません」です

毎日幸せになってください

人生は難しく、コーディングは簡単ではありませんが、笑顔を忘れないでください!

JSタイマーの実装方法

この写真は、「[Beauty] Liz Cremo (著者)」の本「You Look So Beautiful Today」からのものです

以上がJSタイマーの実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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