検索
ホームページウェブフロントエンドVue.jsVue でよく使用される組み込み命令について説明する記事 [百科事典]

この記事では、Vue のすべての組み込み命令をレビューして要約します。いくつかの一般的な命令を最初に説明し、あまり使用されない命令は最後に配置します。

Vue でよく使用される組み込み命令について説明する記事 [百科事典]

#0. 補間式

説明: 補間式は とも呼ばれます。 Mustache 構文 (つまり、二重中括弧) の場合、二重中括弧タグは、対応するコンポーネント インスタンスの msg 属性の値に置き換えられます。同時に、msg 属性が変更されるたびに同期的に更新されます。 [関連する推奨事項: vuejs ビデオ チュートリアル ]

  <template>
    <!-- 1.mustache的基本使用 -->
    <h2 id="message-message">{{message}} - {{message}}</h2>
    
    <!-- 2.是一个表达式 -->
    <h2 id="counter">{{counter * 10}}</h2>
    <h2 id="message-split-reverse-join">{{ message.split(" ").reverse().join(" ") }}</h2>
    
    <!-- 3.也可以调用函数 -->
    <!-- 可以使用computed(计算属性) -->
    <h2 id="getReverseMessage">{{getReverseMessage()}}</h2>
    
    <!-- 4.三元运算符 -->
    <h2 id="isShow-哈哈哈">{{ isShow ? "哈哈哈": "" }}</h2>
    <button>切换</button>

    <!-- 错误用法 -->
    <!-- var name = "abc" -> 赋值语句 -->
    <!-- <h2 id="var-nbsp-name-nbsp-nbsp-abc">{{var name = "abc"}}</h2>
    <h2 id="nbsp-if-isShow-nbsp-nbsp-nbsp-return-nbsp-哈哈哈-nbsp-nbsp">{{ if(isShow) {  return "哈哈哈" } }}</h2> -->
  </template>

1. v-on

手順: バインド要素 イベント リスナー。

省略形: @

パラメータ: event (オブジェクト構文を使用する場合はオプション)

#修飾子:

    .stop
  • - event.stopPropagation() を呼び出します。
  • .prevent
  • ——event.preventDefault() を呼び出します。
  • .capture
  • - キャプチャ モードでイベント リスナーを追加します。
  • .self
  • - ハンドラー関数は、要素自体からイベントが発行された場合にのみトリガーされます。
  • .{keyAlias}
  • - 処理関数は特定のキーの下でのみトリガーされます。
  • .once
  • ——処理関数は最大 1 回トリガーされます。
  • .left
  • - マウスの左ボタン イベントでハンドラー関数のみをトリガーします。
  • .right
  • - マウスの右ボタン イベントでハンドラー関数のみをトリガーします。
  • .middle
  • ——ハンドラー関数は、マウスの中ボタン イベントでのみトリガーされます。
  • .passive
  • - {passive: true } を介して DOM イベントをアタッチします。
詳細説明:

イベントの種類はパラメータで指定します。式はメソッド名またはインライン宣言にすることができ、修飾子が存在する場合は省略することもできます。

通常の要素に使用する場合は、
  • ネイティブ DOM イベント のみをリッスンします。カスタム要素コンポーネントで使用すると、子コンポーネントによってトリガーされる カスタム イベントをリッスンします。 ネイティブ DOM イベントをリッスンする場合、メソッドはネイティブ イベントを唯一のパラメーターとして受け取ります。インライン宣言が使用されている場合、その宣言は特別な
  • $event
  • 変数: v-on:click="handle('ok', $event)" にアクセスできます。
  • v-on
  • は、パラメーターなしでイベント/リスナーのペアのバインド オブジェクトもサポートします。オブジェクト構文を使用する場合、修飾子はサポートされないことに注意してください。
    <!-- 方法处理函数 -->
    <button v-on:click="doThis"></button>
    
    <!-- 动态事件 -->
    <button v-on:[event]="doThis"></button>
    
    <!-- 内联声明 -->
    <button v-on:click="doThat(&#39;hello&#39;, $event)"></button>
    
    <!-- 缩写 -->
    <button @click="doThis"></button>
    
    <!-- 使用缩写的动态事件 -->
    <button @[event]="doThis"></button>
    
    <!-- 停止传播 -->
    <button @click.stop="doThis"></button>
    
    <!-- 阻止默认事件 -->
    <button @click.prevent="doThis"></button>
    
    <!-- 不带表达式地阻止默认事件 -->
    <form @submit.prevent></form>
    
    <!-- 链式调用修饰符 -->
    <button @click.stop.prevent="doThis"></button>
    
    <!-- 按键用于 keyAlias 修饰符-->
    <input @keyup.enter="onEnter" />
    
    <!-- 点击事件将最多触发一次 -->
    <button v-on:click.once="doThis"></button>
    
    <!-- 对象语法 -->
    <button v-on="{ mousedown: doThis, mouseup: doThat }"></button>

説明:

1 つ以上の属性を動的にバインドします。これらの属性は、コンポーネントの prop にすることもできます。

省略形:

: または . (.prop 修飾子を使用する場合)

修飾子:

    .camel
  • - ダッシュで名前が付けられた属性をキャメルケースの名前に変換します。
  • .prop
  • - DOM プロパティへのバインドを強制します。 3.2
  • .attr
  • - DOM 属性への強制バインド。 3.2
使用法:

    class
  • または style 属性をバインドするために使用される場合、v-bind 配列やオブジェクトなどの追加の値の型をサポートします。詳細については、以下のガイドリンクを参照してください。 バインドを処理するとき、Vue はデフォルトで
  • in
  • 演算子を使用して、バインドされたキーと同じ名前の DOM プロパティが要素に定義されているかどうかを確認します。同じ名前のプロパティが存在する場合、Vue はそれを属性として設定するのではなく、DOM プロパティとして割り当てます。この動作は、ほとんどの場合、予期されるバインディング値のタイプと一致しますが、.prop および .attr 修飾子を使用してバインディング モードを明示的に強制することもできます。特に カスタム要素 を扱う場合、これが必要になる場合があります。 コンポーネントの小道具のバインディングに使用する場合、バインドされた小道具は子コンポーネントで正しく宣言される必要があります。
  • パラメータなしで使用すると、複数の属性名とバインディング値のペアを含むオブジェクトをバインドするために使用できます。
  • <!-- 绑定 attribute -->
    <img  src="/static/imghwm/default1.png" data-src="imageSrc" class="lazy" alt="Vue でよく使用される組み込み命令について説明する記事 [百科事典]" >
    
    <!-- 动态 attribute 名 -->
    <button></button>
    
    <!-- 缩写 -->
    <img  src="/static/imghwm/default1.png" data-src="imageSrc" class="lazy" alt="Vue でよく使用される組み込み命令について説明する記事 [百科事典]" >
    
    <!-- 缩写形式的动态 attribute 名 -->
    <button></button>
    
    <!-- 内联字符串拼接 -->
    <img  src="/static/imghwm/default1.png" data-src="'/path/to/images/' + fileName" class="lazy" alt="Vue でよく使用される組み込み命令について説明する記事 [百科事典]" >
    
    <!-- class 绑定 -->
    <div></div>
    <div></div>
    <div></div>
    
    <!-- style 绑定 -->
    <div></div>
    <div></div>
    
    <!-- 绑定对象形式的 attribute -->
    <div></div>
    
    <!-- prop 绑定。“prop” 必须在子组件中已声明。 -->
    <mycomponent></mycomponent>
    
    <!-- 传递子父组件共有的 prop -->
    <mycomponent></mycomponent>
    
    <!-- XLink -->
    <svg><a></a></svg>
3. v-if

説明:

式の値の真偽に基づいて条件付きで要素をレンダリングします。テンプレートのフラグメント。

<h2 id="哈哈哈哈">哈哈哈哈</h2>

4. v-else

说明: 表示 v-if 或 v-if / v-else-if 链式调用的“else 块”。

<h2 id="Coder">Coder</h2>
<h2 id="Bin">Bin</h2>

ishow 为 true 显示 Coder,反之显示 Bin

5. v-else-if

说明: 表示 v-if 的“else if 块”。可以进行链式调用。

<template>
  <input>
  <h2 id="gt-优秀"> 90">优秀</h2>
  <h2 id="gt-良好"> 60">良好</h2>
  <h2 id="不及格">不及格</h2>
</template>

v-model 后面会说明

6. v-show

说明基于表达式值的真假性,来改变元素的可见性。

详细描述v-show 通过设置内联样式的 display CSS 属性来工作,当元素可见时将使用初始 display 值。当条件改变时,也会触发过渡效果。

  

  <script>
    const App = {
      template: &#39;#my-app&#39;,
      data() {
        return {
          isShow: true
        }
      }
    }
    Vue.createApp(App).mount(&#39;#app&#39;);
  </script>

v-show 不支持在 <template></template> 元素上使用,也不能和 v-else 搭配使用。

7. v-model

说明: 在表单输入元素或组件上创建双向绑定。

仅限: <input><select></select><textarea></textarea>、components

修饰符:

  • .lazy ——监听 change 事件而不是 input
  • .number ——将输入的合法符串转为数字
  • .trim ——移除输入内容两端空格

基本使用:

  <template>
    <!-- 1.v-bind value的绑定 2.监听input事件, 更新message的值 -->
    <!-- <input type="text" :value="message" @input="inputChange"> -->

    <input>
    <h2 id="message">{{message}}</h2>
  </template>

  <script>
    const App = {
      template: &#39;#my-app&#39;,
      data() {
        return {
          message: "Hello World"
        }
      },
      methods: {
        inputChange(event) {
          this.message = event.target.value;
        }
      }
    }
    Vue.createApp(App).mount(&#39;#app&#39;);</script>

绑定其他表单:

  <template>
    <!-- 1.绑定textarea -->
    <label>
      自我介绍
      <textarea></textarea>
    </label>
    <h2 id="intro-intro">intro: {{intro}}</h2>

    <!-- 2.checkbox -->
    <!-- 2.1.单选框 -->
    <label>
      <input> 同意协议
    </label>
    <h2 id="isAgree-isAgree">isAgree: {{isAgree}}</h2>

    <!-- 2.2.多选框 -->
    <span>你的爱好: </span>
    <label>
      <input> 篮球
    </label>
    <label>
      <input> 足球
    </label>
    <label>
      <input> 网球
    </label>
    <h2 id="hobbies-hobbies">hobbies: {{hobbies}}</h2>

    <!-- 3.radio -->
    <span>你的爱好: </span>
    <label>
      <input>男
    </label>
    <label>
      <input>女
    </label>
    <h2 id="gender-gender">gender: {{gender}}</h2>

    <!-- 4.select -->
    <span>喜欢的水果: </span>
    <select>
      <option>苹果</option>
      <option>橘子</option>
      <option>香蕉</option>
    </select>
    <h2 id="fruit-fruit">fruit: {{fruit}}</h2>
  </template>

  <script>
    const App = {
      template: &#39;#my-app&#39;,
      data() {
        return {
          intro: "Hello World",
          isAgree: false,
          hobbies: ["basketball"],
          gender: "",
          fruit: "orange"
        }
      },
      methods: {
        commitForm() {
          axios
        }
      }
    }

    Vue.createApp(App).mount(&#39;#app&#39;);
  </script>

v-model修饰符的使用

 <template>
    <!-- 1.lazy修饰符 -->
    <!-- <input type="text" v-model.lazy="message"> -->

    <!-- 2.number修饰符 -->
    <!-- <input type="text" v-model.number="message">
    <h2 id="message">{{message}}</h2>
    <button @click="showType">查看类型</button> -->

    <!-- 3.trim修饰符 -->
    <input>
    <button>查看结果</button>
  </template>

  <script>
    const App = {
      template: &#39;#my-app&#39;,
      data() {
        return {
          message: "Hello World"
        }
      },
      methods: {
        showType() {
          console.log(this.message, typeof this.message);
        },
        showResult() {
          console.log(this.message);
        }
      }
    }

    Vue.createApp(App).mount(&#39;#app&#39;);
  </script>

8. v-for

说明: 基于原始数据多次渲染元素或模板块。

详细描述:

指令值必须使用特殊语法 alias in expression 为正在迭代的元素提供一个别名:

<div>
  {{ item.text }}
</div>

或者,你也可以为索引指定别名 (如果用在对象,则是键值):

<div></div>
<div></div>
<div></div>

v-for 的默认方式是尝试就地更新元素而不移动它们。要强制其重新排序元素,你需要用特殊 attribute key 来提供一个排序提示:

<div>
  {{ item.text }}
</div>

9. v-slot

说明: 用于声明具名插槽或是期望接收 props 的作用域插槽。

缩写: #

参数:插槽名 (可选,默认是 default)

仅限:

  • <template></template>
  • components (用于带有 prop 的单个默认插槽)

示例

<!-- 具名插槽 -->
<baselayout>
  <template>
    Header content
  </template>

  <template>
    Default slot content
  </template>

  <template>
    Footer content
  </template>
</baselayout>

<!-- 接收 prop 的具名插槽 -->
<infinitescroll>
  <template>
    <div>
      {{ slotProps.item.text }}
    </div>
  </template>
</infinitescroll>

<!-- 接收 prop 的默认插槽,并解构 -->
<mouse>
  Mouse position: {{ x }}, {{ y }}
</mouse>

10. v-text

说明: 更新元素的文本内容。

详细描述: v-text 通过设置元素的 textContent 属性来工作,因此它将覆盖元素中所有现有的内容。如果你需要更新 textContent 的部分,应该使用 mustache interpolations 代替。

<span></span>
<!-- 等同于 -->
<span>{{msg}}</span>

11. v-html

说明: 更新元素的 innerHTML

详细描述: v-html 的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用 v-html 来编写模板,不如重新想想怎么使用组件来代替。

安全说明: 在你的站点上动态渲染任意的 HTML 是非常危险的,因为它很容易导致 XSS 攻击。请只对可信内容使用 HTML 插值,绝不要将用户提供的内容作为插值

<div></div>

12. v-pre

说明: 跳过该元素及其所有子元素的编译。

详细描述:元素内具有 v-pre,所有 Vue 模板语法都会被保留并按原样渲染。最常见的用例就是显示原始双大括号标签及内容。

<span>{{ this will not be compiled }}</span>

13. v-once

说明: 跳过该元素及其所有子元素的编译。

详细描述: 在随后的重新渲染,元素/组件及其所有子项将被当作静态内容并跳过渲染。这可以用来优化更新时的性能。

<!-- 单个元素 -->
<span>This will never change: {{msg}}</span>
<!-- 带有子元素的元素 -->
<div>
  <h1 id="comment">comment</h1>
  <p>{{msg}}</p>
</div>
<!-- 组件 -->
<mycomponent></mycomponent>
<!-- `v-for` 指令 -->
      
  • {{i}}

14. v-cloak

说明: 用于隐藏尚未完成编译的 DOM 模板。

详细描述:该指令只在没有构建步骤的环境下需要使用。

  • 当使用直接在 DOM 中书写的模板时,可能会出现一种叫做“未编译模板闪现”的情况:用户可能先看到的是还没编译完成的双大括号标签,直到挂载的组件将它们替换为实际渲染的内容。
  • v-cloak 会保留在所绑定的元素上,直到相关组件实例被挂载后才移除。配合像 [v-cloak] { display: none } 这样的 CSS 规则,它可以在组件编译完毕前隐藏原始模板。
[v-cloak] {
  display: none;
}
<div>
  {{ message }}
</div>

更多编程相关知识,请访问:编程入门!!

以上がVue でよく使用される組み込み命令について説明する記事 [百科事典]の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は掘金社区で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
React vs. Vue:Netflixはどのフレームワークを使用していますか?React vs. Vue:Netflixはどのフレームワークを使用していますか?Apr 14, 2025 am 12:19 AM

netflixusesaCustomframeworkは、「ギボン」ビルトンリアクト、notreactorvuedirectly.1)チームエクスペリエンス:seice basedonfamperivity.2)projectomplerprojects:vueforsplerprojects、racefforcomplexones.3)customeforsneeds:reactofforsmorefloficailie.

フレームワークの選択:Netflixの決定を推進するものは何ですか?フレームワークの選択:Netflixの決定を推進するものは何ですか?Apr 13, 2025 am 12:05 AM

Netflixは、主に、パフォーマンス、スケーラビリティ、開発効率、エコシステム、技術的な負債、およびフレームワーク選択におけるメンテナンスコストを考慮しています。 1。パフォーマンスとスケーラビリティ:JavaとSpringbootが選択され、大規模なデータと高い同時リクエストを効率的に処理します。 2。開発効率とエコシステム:Reactを使用して、フロントエンド開発効率を向上させ、その豊富なエコシステムを利用します。 3.技術的な負債とメンテナンスコスト:node.jsを選択してマイクロサービスを構築して、メンテナンスコストと技術的債務を削減します。

Netflixのフロントエンドの反応、Vue、および未来Netflixのフロントエンドの反応、Vue、および未来Apr 12, 2025 am 12:12 AM

Netflixは、主にReactをフロントエンドフレームワークとして使用し、特定の機能のためにVUEによって補足されます。 1)Reactのコンポーネント化と仮想DOMは、Netflixアプリケーションのパフォーマンスと開発効率を向上させます。 2)VueはNetflixの内部ツールと小規模プロジェクトで使用されており、その柔軟性と使いやすさが重要です。

フロントエンドのvue.js:実際のアプリケーションと例フロントエンドのvue.js:実際のアプリケーションと例Apr 11, 2025 am 12:12 AM

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

Vue.jsとReact:重要な違​​いを理解するVue.jsとReact:重要な違​​いを理解するApr 10, 2025 am 09:26 AM

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

Vue.js vs. React:プロジェクト固有の考慮事項Vue.js vs. React:プロジェクト固有の考慮事項Apr 09, 2025 am 12:01 AM

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

Vueにタグをジャンプする方法Vueにタグをジャンプする方法Apr 08, 2025 am 09:24 AM

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

VUEのコンポーネントジャンプを実装する方法VUEのコンポーネントジャンプを実装する方法Apr 08, 2025 am 09:21 AM

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

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 中国語版

SublimeText3 中国語版

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません