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

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

青灯夜游
リリース: 2022-09-06 19:53:08
転載
2411 人が閲覧しました

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

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

#0. 補間式

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

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

    <!-- 错误用法 -->
    <!-- var name = "abc" -> 赋值语句 -->
    <!-- <h2>{{var name = "abc"}}</h2>
    <h2>{{ 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 v-bind:src="imageSrc" />
    
    <!-- 动态 attribute 名 -->
    <button v-bind:[key]="value"></button>
    
    <!-- 缩写 -->
    <img :src="imageSrc" />
    
    <!-- 缩写形式的动态 attribute 名 -->
    <button :[key]="value"></button>
    
    <!-- 内联字符串拼接 -->
    <img :src="&#39;/path/to/images/&#39; + fileName" />
    
    <!-- class 绑定 -->
    <div :class="{ red: isRed }"></div>
    <div :class="[classA, classB]"></div>
    <div :class="[classA, { classB: isB, classC: isC }]"></div>
    
    <!-- style 绑定 -->
    <div :style="{ fontSize: size + &#39;px&#39; }"></div>
    <div :style="[styleObjectA, styleObjectB]"></div>
    
    <!-- 绑定对象形式的 attribute -->
    <div v-bind="{ id: someProp, &#39;other-attr&#39;: otherProp }"></div>
    
    <!-- prop 绑定。“prop” 必须在子组件中已声明。 -->
    <MyComponent :prop="someThing" />
    
    <!-- 传递子父组件共有的 prop -->
    <MyComponent v-bind="$props" />
    
    <!-- XLink -->
    <svg><a :xlink:special="foo"></a></svg>
    ログイン後にコピー
3. v-if

説明:

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

<h2 v-if="isShow">哈哈哈哈</h2>
ログイン後にコピー

4. v-else

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

<h2 v-if="isShow">Coder</h2>
<h2 v-else>Bin</h2>
ログイン後にコピー

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

5. v-else-if

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

<template id="my-app">
  <input type="text" v-model="score">
  <h2 v-if="score > 90">优秀</h2>
  <h2 v-else-if="score > 60">良好</h2>
  <h2 v-else>不及格</h2>
</template>
ログイン後にコピー

v-model 后面会说明

6. v-show

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

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

  <template id="my-app">
    <h2 v-show="isShow">哈哈哈哈</h2>
  </template>

  <script>
    const App = {
      template: &#39;#my-app&#39;,
      data() {
        return {
          isShow: true
        }
      }
    }
    Vue.createApp(App).mount(&#39;#app&#39;);
  </script>
ログイン後にコピー

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

7. v-model

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

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

修饰符:

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

基本使用:

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

    <input type="text" v-model="message">
    <h2>{{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;);
ログイン後にコピー

绑定其他表单:

  <template id="my-app">
    <!-- 1.绑定textarea -->
    <label for="intro">
      自我介绍
      <textarea name="intro" id="intro" cols="30" rows="10" v-model="intro"></textarea>
    </label>
    <h2>intro: {{intro}}</h2>

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

    <!-- 2.2.多选框 -->
    <span>你的爱好: </span>
    <label for="basketball">
      <input id="basketball" type="checkbox" v-model="hobbies" value="basketball"> 篮球
    </label>
    <label for="football">
      <input id="football" type="checkbox" v-model="hobbies" value="football"> 足球
    </label>
    <label for="tennis">
      <input id="tennis" type="checkbox" v-model="hobbies" value="tennis"> 网球
    </label>
    <h2>hobbies: {{hobbies}}</h2>

    <!-- 3.radio -->
    <span>你的爱好: </span>
    <label for="male">
      <input id="male" type="radio" v-model="gender" value="male">男
    </label>
    <label for="female">
      <input id="female" type="radio" v-model="gender" value="female">女
    </label>
    <h2>gender: {{gender}}</h2>

    <!-- 4.select -->
    <span>喜欢的水果: </span>
    <select v-model="fruit" multiple size="2">
      <option value="apple">苹果</option>
      <option value="orange">橘子</option>
      <option value="banana">香蕉</option>
    </select>
    <h2>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 id="my-app">
    <!-- 1.lazy修饰符 -->
    <!-- <input type="text" v-model.lazy="message"> -->

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

    <!-- 3.trim修饰符 -->
    <input type="text" v-model.trim="message">
    <button @click="showResult">查看结果</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 v-for="item in items">
  {{ item.text }}
</div>
ログイン後にコピー

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

<div v-for="(item, index) in items"></div>
<div v-for="(value, key) in object"></div>
<div v-for="(value, name, index) in object"></div>
ログイン後にコピー

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

<div v-for="item in items" :key="item.id">
  {{ item.text }}
</div>
ログイン後にコピー

9. v-slot

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

缩写: #

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

仅限:

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

示例

<!-- 具名插槽 -->
<BaseLayout>
  <template v-slot:header>
    Header content
  </template>

  <template v-slot:default>
    Default slot content
  </template>

  <template v-slot:footer>
    Footer content
  </template>
</BaseLayout>

<!-- 接收 prop 的具名插槽 -->
<InfiniteScroll>
  <template v-slot:item="slotProps">
    <div class="item">
      {{ slotProps.item.text }}
    </div>
  </template>
</InfiniteScroll>

<!-- 接收 prop 的默认插槽,并解构 -->
<Mouse v-slot="{ x, y }">
  Mouse position: {{ x }}, {{ y }}
</Mouse>
ログイン後にコピー

10. v-text

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

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

<span v-text="msg"></span>
<!-- 等同于 -->
<span>{{msg}}</span>
ログイン後にコピー

11. v-html

说明: 更新元素的 innerHTML

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

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

<div v-html="html"></div>
ログイン後にコピー

12. v-pre

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

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

<span v-pre>{{ this will not be compiled }}</span>
ログイン後にコピー

13. v-once

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

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

<!-- 单个元素 -->
<span v-once>This will never change: {{msg}}</span>
<!-- 带有子元素的元素 -->
<div v-once>
  <h1>comment</h1>
  <p>{{msg}}</p>
</div>
<!-- 组件 -->
<MyComponent v-once :comment="msg" />
<!-- `v-for` 指令 -->
<ul>
  <li v-for="i in list" v-once>{{i}}</li>
</ul>
ログイン後にコピー

14. v-cloak

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

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

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

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

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

関連ラベル:
ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
関連するチュートリアル
人気のおすすめ
最新のコース
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート