With の使用に関する詳細な分析

青灯夜游
リリース: 2020-10-23 17:45:58
転載
2550 人が閲覧しました

With の使用に関する詳細な分析

with はステートメントのスコープ チェーンを拡張するために使用されますが、混乱を招くエラーや互換性の問題の原因となる可能性があるため、一般に with ステートメントの使用は推奨されません。 Vue のソースコードには with 文を使用した機能ポイントがあるため、フレームワークのソースコードを読みやすくするために、その機能を紹介します。

パフォーマンスの長所と短所

長所

withステートメントを使用すると、パフォーマンスの低下を引き起こすことなく変数の長さを短縮できます。追加の計算量は最小限です。 「with」を使用すると、不必要なポインター パス解決操作を減らすことができます。ただし、ほとんどの場合、with を使用しなくても、一時変数を使用してポインターを保存するか、call を使用することで同じ効果が得られます。

欠点

withステートメントを使用すると、プログラムは変数値を検索するときに、最初に指定されたオブジェクト内を検索します。したがって、このオブジェクトの属性ではない変数を見つけるのは非常に遅くなります。

let obj = { a: 1, b: 2, c: 3 } with(obj){ console.log(a) //1 console.log(b) //2 console.log(c) //3 }
ログイン後にコピー

このコードでは、with コード ブロック内の各変数に関連付けられた obj オブジェクトは、このローカル変数がobj オブジェクト プロパティが同じ名前を持つ場合、このローカル変数は obj オブジェクトのプロパティを指します。

function fn(obj){ with(obj){ a = 1; } } let obj1 = { a: 2 } let obj2 = { b: 3 } fn(obj1); console.log(obj1.a) //1 fn(obj2) console.log(obj2.a) //undefined console.log(a) //1,变量a被泄漏到全局作用域链上
ログイン後にコピー

上の例では、obj1 には属性 a がありますが、obj2 には属性 a がありません。 fn(obj) は、オブジェクト参照である obj 仮パラメータを受け取り、with(obj) を実行します。 with コード ブロック内では、a は実際には参照であり、a に 1 が割り当てられます。

obj2 を with に渡す場合、with で宣言されたスコープは obj2 であり、このスコープから a のクエリが開始されます。識別子 a は、obj2 のスコープ、fn のスコープ、およびグローバル スコープで見つかりませんでした。したがって、非厳密モードでは、グローバル変数がグローバル スコープに自動的に作成され、strictモードでは、ReferenceErrorエラーがスローされます。

パフォーマンスの低下

コード内で with が使用されている場合、JS エンジンは、コンパイル フェーズでは識別子に関する判断が無効であると単純に想定することしかできません。コンパイル実装者は、渡されたスコープ オブジェクトが誰であるかを知る方法もありません。したがって、コンパイル フェーズ中に JS エンジンによって実行されるパフォーマンスの最適化は無効になります。最悪のシナリオは、with が出現すると、すべての最適化が無意味になってしまうことです。最も簡単な方法は、最適化を行わないことです。その場合、実行速度が非常に遅くなりますが、これは避けられない事実です。

With

Vue の Vue は、コンパイル時にテンプレートから対応するレンダリング関数を生成します。このレンダリング関数では with ステートメントが使用されます。上記によると with ステートメントの使用は推奨されていないとのことですが、なぜ Vue では with ステートメントが使用されるのでしょうか?

関連する推奨事項: 「

vue.js チュートリアル

function render () { with (this) { return _c('p',{on:{"click":change}},[_c('span',[_v(_s(number))]),_v(" "),_c('span', [_v(_s(name))])]) } }
ログイン後にコピー
with のスコープはテンプレートのスコープと正確に一致するため、テンプレートのコンパイル プロセスを大幅に簡素化できます。 with のコード量は非常に少なく、スコープの処理を JS エンジンに任せた方が確実です。もちろん、最も理想的な状況は with の使用を排除することです。プリコンパイル中に、最初のコンパイルによって生成されたコードは自動的に追加処理を受け、完全な AST 分析を使用してスコープを処理し、with を削除し、ES6 をサポートします。方法、文法。つまり、webpack vue を使用する場合、最終的に生成されるコードには with がありません。

関連する推奨事項:


2020 フロントエンド vue インタビューの質問の概要 (回答付き)

vue チュートリアル推奨: 2020 年の最新の vue.js ビデオ チュートリアル 5 選

プログラミング関連の知識の詳細については、

プログラミング入門をご覧ください。 !

以上がWith の使用に関する詳細な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!