中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue有哪些常用api

發布時間:2022-03-07 14:45:09 來源:億速云 閱讀:489 作者:小新 欄目:web開發

這篇文章主要為大家展示了“vue有哪些常用api”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“vue有哪些常用api”這篇文章吧。

vue的api有:1、nextTick;2、mixin;3、“$forceUpdate”;4、set和delete;5、filter;6、directive;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 更新了
  })

說明:

  • callback:延遲回調函數

  • context:可選的object

ps:2.1.0 起新增:如果沒有提供回調且在支持 Promise 的環境中,則返回一個 Promise。請注意 Vue 不自帶 Promise 的 polyfill,所以如果你的目標瀏覽器不原生支持 Promise (IE:你們都看我干嘛),你得自己提供 polyfill。

擴展: 關于nextTick的執行機制和使用場景,我們還必須掌握類似的requestAnimationFrame() 和 process.nextTick(), 前者是瀏覽器自帶的監聽(在下次重繪之前執行),后者是node環境下,在下一個事件輪詢的時間點上執行。

mixin


功能: 注冊一個混入,影響注冊之后所有創建的每個 Vue 實例。插件作者可以使用混入,向組件注入自定義的行為。
用法:

// 為自定義的選項 'myOption' 注入一個處理器。
Vue.mixin({
  created: function () {
    var myOption = this.$options.myOption
    if (myOption) {
      console.log(myOption)
    }
  }
})

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

說明:

  • object:一個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 不能檢測到 property 被刪除的限制

filter


功能: 用于一些常見的文本格式化和一些規范數據mapping。
用法:

<!-- 在雙花括號中 -->
{{ message | capitalize }}

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

new Vue({
  // ...
})

說明:

  • 過濾器函數總接收表達式的值 (之前的操作鏈的結果) 作為第一個參數。

  • 過濾器應該被添加在 JavaScript 表達式的尾部,由“管道”符號指示。

ps:過濾器可以接受多個參數,如{{ message | filterA('arg1', arg2) }},這里,filterA 被定義為接收三個參數的過濾器函數。其中 message 的值作為第一個參數,普通字符串 'arg1' 作為第二個參數,表達式 arg2 的值作為第三個參數。

directive


功能: 用于注冊自定義指令。
用法:

<!-- 當頁面加載時,該元素將獲得焦點 --> 
<input v-focus>
// 注冊一個全局自定義指令 `v-focus`
Vue.directive('focus', {
  // 當被綁定的元素插入到 DOM 中時……
  inserted: function (el) {
    // 聚焦元素
    el.focus()
  }
})
// 注冊局部指令,組件中也接受一個 directives 的選項
directives: {
  focus: {
    // 指令的定義
    inserted: function (el) {
      el.focus()
    }
  }
}

說明:

  • inserted 只是注冊指令的其中一個插值函數,完整的注冊屬性還可以包括:

    • bind:只調用一次,指令第一次綁定到元素時調用,在這里可以進行一次性的初始化設置。

    • inserted:被綁定元素插入父節點時調用(僅保證父節點存在,但不一定已被插入文檔中)。

    • update:所在組件的 VNode 更新時調用,但是可能發生在其子 VNode 更新之前。指令的值可能發生了改變,也可能沒有,但是可以通過比較更新前后的值來忽略不必要的模板更新。

    • componentUpdated:指令所在組件的 VNode 及其子 VNode 全部更新后調用。

    • unbind:只調用一次,指令與元素解綁時調用。

Vue.directive('my-directive', {
  bind: function () {},
  inserted: function () {},
  update: function () {},
  componentUpdated: function () {},
  unbind: function () {}
})

v-model 語法糖

v-model 常用于表單元素上進行數據的雙向綁定,比如 <input>。除了原生的元素,它還能在自定義組件中使用。

v-model 是一個語法糖,可以拆解為 props: value 和 events: input。就是說組件必須提供一個名為 value 的 prop,以及名為 input 的自定義事件,滿足這兩個條件,使用者就能在自定義組件上使用 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: 'InputNumber',
    props: {
      value: {
        type: Number
      }
    },
    data () {
      return {
        currentValue: this.value
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit('input', 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 '../components/input-number/input-number.vue';

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

或:

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

  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: 'InputNumber',
    props: {
      number: {
        type: Number
      }
    },
    model: {
      prop: 'number',
      event: 'change'
    },
    data () {
      return {
        currentValue: this.number
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit('number', 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: 'InputNumber',
    props: {
      value: {
        type: Number
      }
    },
    methods: {
      increase (val) {
        this.$emit('update:value', this.value + val);
      }
    }
  }
</script>

用例:

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

  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() {
}

以上是“vue有哪些常用api”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

获嘉县| 兴隆县| 伊吾县| 南皮县| 嫩江县| 广丰县| 洪泽县| 定襄县| 灵武市| 百色市| 原平市| 常德市| 武安市| 枣阳市| 晋州市| 洞口县| 马公市| 呼伦贝尔市| 葵青区| 德兴市| 三穗县| 丰宁| 泽普县| 龙井市| 汉沽区| 宿迁市| 宜春市| 恩施市| 石台县| 贵溪市| 新余市| 常熟市| 松江区| 阿坝| 玉田县| 丹凤县| 咸阳市| 石首市| 河间市| 天等县| 容城县|