この記事では、Vue 命令 v-show と v-if を比較し、v-show と v-if の違いを紹介し、v-show と v-if の使用シナリオについて説明します。皆さんのお役に立てれば幸いです!
1. v-show と v-if の違い
vue では、v-show と v-if の両方が使用されます。要素をページに表示するかどうかを制御します。
v-show の表示と非表示は要素の CSS の表示属性を操作するため、v-show を使用して要素を非表示にしても、要素の dom ノードはページ上に残ります。 v-if 表示と非表示は、dom 要素全体を追加または削除することです。 [関連する推奨事項: vuejs ビデオ チュートリアル ]
v-if 切り替えには部分的なコンパイル/アンインストール プロセスがあります。切り替えプロセス中、内部イベント リスニングとサブv-showはcssのdisplay属性を操作するだけです。
v-if は true の条件付きレンダリングです。これにより、条件付きブロック内のイベント リスナーとサブコンポーネントが、切り替え中に適切に破棄され、再作成されます。レンダリング条件が false の場合にのみ操作は実行されず、true になるまでレンダリングされません。
v-show は、false から true に変更されるときにコンポーネントのライフサイクルをトリガーしません。v-if が false から true に変更されると、コンポーネントの beforeCreate、create、beforeMount がトリガーされます。 , マウントされたライフサイクルフックは、コンポーネントが true から false に変わると、コンポーネントの beforeDestory メソッドと破棄されたメソッドをトリガーします。
パフォーマンス消費量の点では、v-if はスイッチング消費量が多く、v-show は初期レンダリング消費量が多くなります。
2. v-show と v-if の使用シナリオ
v-if と v-show はどちらも dom の配置を制御できます。ページ上の要素。表示と非表示
v-if は、v-show (dom ノードの追加と削除の直接操作) よりも高価です。非常に頻繁に切り替える必要がある場合は、次を使用します。 v-show. そうですね、実行時に条件がほとんど変わらない場合は、v-if
#3. v-show と v-if## の原理の分析
- # v-show が true か false かに関係なく、要素は常にレンダリングされます。ソース コードでは、v-show 命令にバインドされている要素の外側の層にネストされた遷移がある場合、 el, の外層にネストされた遷移がない場合は、抽象構文の判定用に el.style.display
export const vShow: ObjectDirective<VShowElement> = { beforeMount(el, { value }, { transition }) { el._vod = el.style.display === 'none' ? '' : el.style.display if (transition && value) { transition.beforeEnter(el) } else { setDisplay(el, value) } }, mounted(el, { value }, { transition }) { if (transition && value) { transition.enter(el) } }, updated(el, { value, oldValue }, { transition }) { // ... }, beforeUnmount(el, { value }) { setDisplay(el, value) } }
- v-if を取得するだけでよいツリーはコード文字列に変換されます。 v-if が false の場合、render 関数によって生成された vnode にはレンダリングされるノードが含まれませんが、注釈付きの vnode ノードがプレースホルダーとして含まれます
export const transformIf = createStructuralDirectiveTransform( /^(if|else|else-if)$/, (node, dir, context) => { return processIf(node, dir, context, (ifNode, branch, isRoot) => { // ... return () => { if (isRoot) { ifNode.codegenNode = createCodegenNodeForBranch( branch, key, context ) as IfConditionalExpression } else { // attach this branch's codegen node to the v-if root. const parentCondition = getParentCondition(ifNode.codegenNode!) parentCondition.alternate = createCodegenNodeForBranch( branch, key + ifNode.branches.length - 1, context ) } } }) } )
以上がVue の命令 v-show と v-if を比較し、使用シナリオについて説明しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Vue.jsは、複雑なユーザーインターフェイスを構築するのに適した進歩的なJavaScriptフレームワークです。 1)そのコア概念には、レスポンシブデータ、コンポーネント、仮想DOMが含まれます。 2)実際のアプリケーションでは、TODOアプリケーションを構築し、Vuerouterを統合することで実証できます。 3)デバッグするときは、vuedevtools and Console.logを使用することをお勧めします。 4)パフォーマンスの最適化は、V-IF/V-Show、リストレンダリング最適化、コンポーネントの非同期負荷などを通じて達成できます。

Vue.JSは中小企業から中規模のプロジェクトに適していますが、Reactは大規模で複雑なアプリケーションにより適しています。 1。VUE.JSのレスポンシブシステムは、依存関係追跡を介してDOMを自動的に更新し、データの変更を簡単に管理できるようにします。 2.反応は一方向のデータフローを採用し、データは親コンポーネントから子コンポーネントに流れ、明確なデータフローと簡単な抽出構造を提供します。

VUE.JSは、中小規模のプロジェクトや迅速な反復に適していますが、Reactは大規模で複雑なアプリケーションに適しています。 1)Vue.jsは使いやすく、チームが不十分な状況やプロジェクトスケールが小さい状況に適しています。 2)Reactにはより豊富なエコシステムがあり、高性能で複雑な機能的ニーズを持つプロジェクトに適しています。

VUEでタグのジャンプを実装する方法には、HTMLテンプレートでAタグを使用してHREF属性を指定する方法が含まれます。 VUEルーティングのルーターリンクコンポーネントを使用します。 JavaScriptでこれを使用します。$ router.push()メソッド。パラメーターはクエリパラメーターに渡すことができ、ルートは動的ジャンプのルーターオプションで構成されています。

VUEでコンポーネントジャンプを実装するための次の方法があります。Router-Linkと&lt; router-view&gt;を使用してください。ハイパーリンクジャンプを実行し、ターゲットパスとして属性を指定するコンポーネント。 &lt; router-view&gt;を使用してください現在ルーティングされているレンダリングされているコンポーネントを表示するコンポーネント。プログラマティックナビゲーションには、router.push()およびrouter.replace()メソッドを使用します。前者は歴史を保存し、後者は記録を残さずに現在のルートに取って代わります。

VUEにDIV要素をジャンプするには、VUEルーターを使用してルーターリンクコンポーネントを追加するには、2つの方法があります。 @clickイベントリスナーを追加して、これを呼び出します。$ router.push()メソッドをジャンプします。

VUEにデータを渡す主な方法は2つあります。PROPS:一方向データバインディング、親コンポーネントから子コンポーネントにデータを渡します。イベント:イベントとカスタムイベントを使用してコンポーネント間でデータを渡します。

Vue.jsは、ジャンプする3つの方法を提供します。ネイティブJavaScript API:Window.Location.hrefを使用してジャンプします。 Vueルーター:&lt; router-link&gt;を使用してくださいタグまたはこれ。$ router.push()ジャンプする方法。 Vuex:トリガールートジャンプを発送するか、突然変異をコミットします。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

SublimeText3 中国語版
中国語版、とても使いやすい
