久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

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

(學習視頻分享:vuejs教程、web前端)

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
欧美午夜精彩| 99视频精品全国免费| 亚洲一区二区三区久久久| 久久久久国产一区二区| 日韩免费视频| 欧美激情福利| 国产精品密蕾丝视频下载| 亚洲精品日本| 综合干狼人综合首页| 丝袜美腿亚洲一区| 亚洲深夜av| 亚洲一区二区三区高清| 久久av一区| 在线亚洲自拍| 老司机精品久久| 免费人成精品欧美精品| 久久亚洲美女| 日本免费在线视频不卡一不卡二| 日本在线不卡视频一二三区| 欧美在线91| 免费在线成人| 91亚洲人成网污www| 日本一区二区高清不卡| 四季av一区二区凹凸精品| 伊人久久av| 久久狠狠婷婷| 欧美亚洲精品在线| 亚洲欧美日本国产专区一区| 伊人久久亚洲美女图片| 老色鬼久久亚洲一区二区| 亚洲网址在线观看| 久久国产精品免费精品3p| 欧美国产另类| 激情国产在线| 黑丝美女一区二区| 丝袜诱惑制服诱惑色一区在线观看| 免费久久99精品国产| 亚洲欧美日韩国产一区| 蜜臀精品久久久久久蜜臀| 亚洲久久视频| 欧美日韩国产传媒| 蜜臀久久99精品久久久久宅男| 石原莉奈在线亚洲二区| 欧美日韩91| 久久99蜜桃| 色偷偷偷在线视频播放| 日韩一级精品| 国产欧美日本| 亚洲不卡系列| 亚洲尤物av| 国产成人免费视频网站视频社区| 国产99亚洲| 亚洲欧洲美洲国产香蕉| 精品视频自拍| 欧美日韩国产欧| 欧美日韩18| 亚洲va在线| 日韩精品久久久久久| av中文字幕在线观看第一页| 国产精品99免费看| 日本不卡一区二区| 日韩精品专区| 在线观看亚洲精品福利片| 欧美黄色一区二区| 中文日韩欧美| 精品久久久中文字幕| 最新亚洲国产| 久久精品国产大片免费观看| 老司机精品视频网| 国产亚洲精品自拍| 婷婷综合福利| 新版的欧美在线视频| 一本综合精品| 蜜臀国产一区| 天堂av在线一区| 成人国产精品一区二区网站| 久久亚洲欧美| 久久精品在线| 国产区精品区| 国产亚洲高清视频| 国产69精品久久| 亚洲精品精选| 久久国产小视频| 国产精品入口久久| 婷婷成人在线| 麻豆一区二区三| 亚洲精品免费观看| 香蕉久久精品| 美女视频黄免费的久久| 黄色精品网站| 国产一区二区三区四区二区| 午夜久久av| 亚洲激情社区| 欧洲精品一区二区三区| 国产视频网站一区二区三区| 中文久久精品| 亚洲第一精品影视| 中文av在线全新| 国产欧美日韩在线观看视频| 国产精品丝袜xxxxxxx| 亚洲黄色网址| 国产精品久一| 日韩和欧美一区二区三区| 影音国产精品| 国内一区二区三区| 国产精品亚洲人成在99www| 亚洲午夜免费| 免费一区二区视频| 亚洲免费影视| 亚洲一区区二区| 国产综合精品| 久久久国产亚洲精品| 中文字幕一区久| 精品淫伦v久久水蜜桃| 欧美一区成人| 青青草精品视频| 日韩中文字幕亚洲一区二区va在线| 午夜免费一区| 日韩精品免费一区二区在线观看| 国产美女久久| 日韩一区二区三区精品| 日韩专区在线视频| 91久久中文| 欧美日韩国产探花| 91高清一区| 亚洲国产不卡| 最新亚洲激情| 丝袜美腿亚洲色图| 免费久久99精品国产自在现线| 午夜影院欧美| 99国产精品99久久久久久粉嫩| 国产综合婷婷| 欧美日韩国产免费观看| 99成人在线| 精品日韩毛片| 国产精品毛片在线看| 亚洲欧美日韩一区在线观看| 免费久久99精品国产自在现线| 亚洲综合日韩| 亚洲三级毛片| 国产精品一区三区在线观看| 欧美激情三区| 91视频一区| 久久久久久美女精品| 日韩午夜av在线| 亚洲精品动态| 国产亚洲第一伦理第一区| 欧美日本不卡高清| 久久久久亚洲精品中文字幕| 国产欧美在线观看免费| 久久久国产精品网站| 色综合五月天| 亚洲欧美伊人| 亚洲伊人影院| 国产精品久久久久久久久免费高清| 欧美精品二区| 欧美精品资源| 综合欧美亚洲| 久久久精品区| 国产99久久| 亚洲精品动态| 久久久国产精品网站| 今天的高清视频免费播放成人| 亚洲综合婷婷| 国产伦精品一区二区三区视频 | 亚洲精一区二区三区| 国产精品亚洲四区在线观看| 麻豆91精品91久久久的内涵| 黄色aa久久| 亚洲欧美不卡| 国产美女视频一区二区| 国产日韩在线观看视频| 高潮久久久久久久久久久久久久| 精品国产欧美| 丝袜美腿一区| 久久免费国产| 一区二区电影在线观看| 91麻豆精品| 精品国产欧美日韩一区二区三区| 国产一区二区三区四区| 亚洲激情二区| 日韩av一区二区在线影视| 国产精品sss在线观看av| 中文在线а√在线8| 亚洲自啪免费| 国产精品最新自拍| 欧美成人aaa| 欧美片第1页| 午夜日韩福利| 欧美一区自拍| 美女国产精品久久久| 日韩精品永久网址| 99亚洲视频| 日韩一区网站| 97精品97| 黄色日韩精品| 国产精品久久国产愉拍| 日韩欧美三级| 国产精品99一区二区三区| 国产尤物精品|