ホームページ >ウェブフロントエンド >フロントエンドQ&A >Vue で一般的に使用される API は何ですか?

Vue で一般的に使用される API は何ですか?

青灯夜游
青灯夜游オリジナル
2022-03-07 14:12:382673ブラウズ

Vue の API には、1. nextTick、2. mixin、3. “$forceUpdate”、4. 設定と削除、5. フィルター、6. ディレクティブ、7. “$root”、8. “ $ el"; 9. "$data"; 10. "$props" など

Vue で一般的に使用される API は何ですか?

このチュートリアルの動作環境: Windows7 システム、vue2.9.6 バージョン、DELL G3 コンピューター。

nextTick


関数: 次の Dom 更新サイクルが終了した後に遅延コールバックを追加します。データを変更した後、更新された Dom を取得できます。
使用法:

Vue.nextTick( [callback, context] )
vm.$nextTick( [callback] )
// 用法2
// 作为一个 Promise 使用 (2.1.0 起新增)
Vue.nextTick()
  .then(function () {
    // DOM 更新了
  })

説明:

    ##コールバック: 遅延コールバック関数
  • コンテキスト: オプションのオブジェクト
ps: 2.1.0 以降の新機能: コールバックが提供されず、Promise をサポートする環境では、Promise が返されます。 Vue には Promise ポリフィルが付属していないことに注意してください。そのため、ターゲット ブラウザが Promise をネイティブにサポートしていない場合 (つまり、なぜ私を見ているのですか)、自分でポリフィルを提供する必要があります。

拡張: nextTick の実行メカニズムと使用シナリオに関しては、同様の requestAnimationFrame() と process.nextTick() も習得する必要があります。前者はブラウザー自身のモニターです (次の再描画前)実行)、後者はノード環境内の次のイベント ポーリング時点で実行されます。

mixin


関数: 登録後に作成されたすべての Vue インスタンスに影響を与えるミックスインを登録します。プラグイン作成者は、ミックスインを使用してカスタム動作をコンポーネントに挿入できます。
使用法:

// 为自定义的选项 'myOption' 注入一个处理器。
Vue.mixin({
  created: function () {
    var myOption = this.$options.myOption
    if (myOption) {
      console.log(myOption)
    }
  }
})

new Vue({
  myOption: 'hello!'
})
// => "hello!"

説明:

##オブジェクト: vm 属性またはメソッド
  • ps: グローバル ミックスインは、個別に作成された各 Vue インスタンス (サードパーティ コンポーネントを含む) に影響するため、注意して使用してください。ほとんどの場合、これは上記の例のようなカスタム オプションにのみ適用されます。アプリケーション ミックスインの繰り返しを避けるために、プラグインとして公開することをお勧めします。

$forceUpdate


関数:

Vue インスタンスを強制的に再レン​​ダリングします。 使用法:

vm.$forceUpdate()

説明:

すべてのサブコンポーネントではなく、インスタンス自体と、スロットのコンテンツに挿入されたサブコンポーネントにのみ影響することに注意してください。 set, delete


関数:

レスポンシブ データのプロパティを設定および削除し、同時にビューの更新をトリガーします。 使用法:

// 用法1
Vue.set( target, key, value )
Vue.delete( target, key )
// 用法2
vm.$set( target, key, value )
vm.$delete( target, key )

説明:

target: ターゲット オブジェクト
  • key: 追加されるプロパティ名
  • value: 追加するプロパティ値
  • ps: Vue がプロパティの削除を検出できないという制限を回避できる主な使用シナリオ

filter


関数:

一般的なテキストの書式設定と標準のデータ マッピングに使用されます。 使用法:

<!-- 在双花括号中 -->
{{ message | capitalize }}

<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>
// 注册
filters: {
  capitalize: function (value) {
    if (!value) return &#39;&#39;
    value = value.toString()
    return value.charAt(0).toUpperCase() + value.slice(1)
  }
}
// 全局注册
Vue.filter(&#39;capitalize&#39;, function (value) {
  if (!value) return &#39;&#39;
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
  // ...
})

説明:

フィルター関数は常に式の値 (前の操作チェーンの結果) を最初の引数として使用します。
  • フィルターは、「パイプ」記号で示される JavaScript 式の最後に追加する必要があります。
ps: フィルターは、{{ message | filterA('arg1', arg2) }} などの複数のパラメーターを受け入れることができます。ここでは、filterA は 3 つのパラメーターを受け取るフィルターとして定義されています.デバイス機能。 message の値が最初のパラメーターとして使用され、通常の文字列 'arg1' が 2 番目のパラメーターとして使用され、式 arg2 の値が 3 番目のパラメーターとして使用されます。

ディレクティブ


関数:

カスタム命令を登録するために使用されます。 使用法:

<!-- 当页面加载时,该元素将获得焦点 --> 
<input v-focus>
// 注册一个全局自定义指令 `v-focus`
Vue.directive(&#39;focus&#39;, {
  // 当被绑定的元素插入到 DOM 中时……
  inserted: function (el) {
    // 聚焦元素
    el.focus()
  }
})
// 注册局部指令,组件中也接受一个 directives 的选项
directives: {
  focus: {
    // 指令的定义
    inserted: function (el) {
      el.focus()
    }
  }
}

手順:

挿入されたのは、登録コマンドの補間関数の 1 つにすぎません。完全な登録属性も含めることができます:
  • bind: 1 回だけ呼び出され、命令が初めて要素にバインドされたときに呼び出されます。1 回限りの初期化設定をここで実行できます。
    • inserted: バインドされた要素が親ノードに挿入されるときに呼び出されます (親ノードのみが存在することが保証されますが、必ずしもドキュメントに挿入されるわけではありません)。
    • update: コンポーネントの VNode が更新されるときに呼び出されますが、その子 VNode が更新される前に発生する場合もあります。ディレクティブの値は変更されている場合と変更されていない場合がありますが、更新前後の値を比較することで、不要なテンプレートの更新を無視できます。
    • componentUpdated: 命令が配置されているコンポーネントのすべての VNode とそのサブ VNode が更新された後に呼び出されます。
    • unbind: 命令が要素からバインドされていないときに、1 回だけ呼び出されます。
    Vue.directive(&#39;my-directive&#39;, {
      bind: function () {},
      inserted: function () {},
      update: function () {},
      componentUpdated: function () {},
      unbind: function () {}
    })
  • v-model 構文 Sugar


v-model は、< などのフォーム要素上のデータの双方向バインディングによく使用されます。 ;入力> 。ネイティブ要素に加えて、カスタム コンポーネントでも使用できます。

v-model は、props: value と events: input に分解できる糖衣構文です。つまり、コンポーネントは value という名前のプロップと input という名前のカスタム イベントを提供する必要があります。これら 2 つの条件が満たされる場合、ユーザーはカスタム コンポーネントで v-model を使用できます。たとえば、次の例では数値セレクターを実装しています。

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ currentValue }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      value: {
        type: Number
      }
    },
    data () {
      return {
        currentValue: this.value
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit(&#39;input&#39;, this.currentValue);
      }
    }
  }
</script>

props 一般不能在组件内修改,它是通过父级修改的,因此实现 v-model 一般都会有一个 currentValue 的内部 data,初始时从 value 获取一次值,当 value 修改时,也通过 watch 监听到及时更新;组件不会修改 value 的值,而是修改 currentValue,同时将修改的值通过自定义事件 input 派发给父组件,父组件接收到后,由父组件修改 value。所以,上面的数字选择器组件可以有下面两种使用方式:

<template>
  <InputNumber v-model="value" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    }
  }
</script>

或:

<template>
  <InputNumber :value="value" @input="handleChange" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    },
    methods: {
      handleChange (val) {
        this.value = val;
      }
    }
  }
</script>

如果你不想用 value 和 input 这两个名字,从 Vue.js 2.2.0 版本开始,提供了一个 model 的选项,可以指定它们的名字,所以数字选择器组件也可以这样写:

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ currentValue }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      number: {
        type: Number
      }
    },
    model: {
      prop: &#39;number&#39;,
      event: &#39;change&#39;
    },
    data () {
      return {
        currentValue: this.number
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit(&#39;number&#39;, this.currentValue);
      }
    }
  }
</script>

在 model 选项里,就可以指定 prop 和 event 的名字了,而不一定非要用 value 和 input,因为这两个名字在一些原生表单元素里,有其它用处。

.sync 修饰符

如果你使用过 Vue.js 1.x,一定对 .sync 不陌生。在 1.x 里,可以使用 .sync 双向绑定数据,也就是父组件或子组件都能修改这个数据,是双向响应的。在 Vue.js 2.x 里废弃了这种用法,目的是尽可能将父子组件解耦,避免子组件无意中修改了父组件的状态。

不过在 Vue.js 2.3.0 版本,又增加了 .sync 修饰符,但它的用法与 1.x 的不完全相同。2.x 的 .sync 不是真正的双向绑定,而是一个语法糖,修改数据还是在父组件完成的,并非在子组件。

仍然是数字选择器的示例,这次不用 v-model,而是用 .sync,可以这样改写:

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ value }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      value: {
        type: Number
      }
    },
    methods: {
      increase (val) {
        this.$emit(&#39;update:value&#39;, this.value + val);
      }
    }
  }
</script>

用例:

<template>
  <InputNumber :value.sync="value" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    }
  }
</script>

看起来要比 v-model 的实现简单多,实现的效果是一样的。v-model 在一个组件中只能有一个,但 .sync 可以设置很多个。.sync 虽好,但也有限制,比如:

  • 不能和表达式一起使用(如 v-bind:title.sync="doc.title + '!'" 是无效的);

  • 不能用在字面量对象上(如 v-bind.sync="{ title: doc.title }" 是无法正常工作的)。

其它简单的常用属性和方法

// console.log(vm.$root); 
vm.$root    //实例对象

vm.$el  //根元素(真实的DOM元素)
// console.log(vm.$el);

vm.$el.innerHTML    //得到根元素(真实的DOM元素)中的内容
// console.log(vm.$el.innerHTML);

vm.$data    //实例下的data对象
// console.log(vm.$data);

vm.$options     //实例下的挂载项
// console.log(vm.$options);

vm.$props   //组件之间通信的数据
// console.log(vm.$props);

vm.$parent      //在组件中,指父元素
// console.log(vm.$parent);

vm.$children    //在组件中,指子代元素
// console.log(vm.$children);

vm.$attrs   //用来获取父组件传递过来的所有属性
// console.log(vm.$attrs);

vm.$listeners   //用来获取父组件传递过来的所有方法
// console.log(vm.$listeners);

vm.$slots   //组件中的插槽
// console.log(vm.$slots);

vm.$scopedSlots     //用来访问作用域插槽
// console.log(vm.$scopedSlots);

vm.$refs    //用来定位DOM元素(使用ref进行追踪)
// console.log(vm.$refs);

vm.$watch   //用于监听数据(在vue文件中使用后会自动销毁)
// console.log(vm.$watch);

vm.$emit    //用于派发事件(常用于数据通信)
// console.log(vm.$emit);

vm.$on  //用于监听事件的派发
// console.log(vm.$on);

vm.$once    //只监听事件一次(之后不监听)
// console.log(vm.$once);

//生命周期
beforeCreate() {
}
created() {
}
beforeMount() {
}
mounted() {
}
beforeUpdate() {
}
updated() {
}
beforeDestroy() {
}
destroyed() {
}

(学习视频分享:vuejs教程web前端

以上がVue で一般的に使用される API は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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