成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

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

本教程操作環(huán)境:windows7系統(tǒng)、vue2.9.6版,DELL G3電腦。

nextTick


功能: 添加在下次Dom更新循環(huán)結(jié)束之后的延遲回調(diào),修改數(shù)據(jù)之后,可以獲取更新后的Dom。
用法:

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

說(shuō)明:

  • callback:延遲回調(diào)函數(shù)
  • context:可選的object

ps:2.1.0 起新增:如果沒(méi)有提供回調(diào)且在支持 Promise 的環(huán)境中,則返回一個(gè) Promise。請(qǐng)注意 Vue 不自帶 Promise 的 polyfill,所以如果你的目標(biāo)瀏覽器不原生支持 Promise (IE:你們都看我干嘛),你得自己提供 polyfill。

擴(kuò)展: 關(guān)于nextTick的執(zhí)行機(jī)制和使用場(chǎng)景,我們還必須掌握類似的requestAnimationFrame() 和 process.nextTick(), 前者是瀏覽器自帶的監(jiān)聽(tīng)(在下次重繪之前執(zhí)行),后者是node環(huán)境下,在下一個(gè)事件輪詢的時(shí)間點(diǎn)上執(zhí)行。

mixin


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

// 為自定義的選項(xiàng) 'myOption' 注入一個(gè)處理器。 Vue.mixin({   created: function () {     var myOption = this.$options.myOption     if (myOption) {       console.log(myOption)     }   } })  new Vue({   myOption: 'hello!' }) // => "hello!"

說(shuō)明:

  • object:一個(gè)vm的屬性或方法

ps:請(qǐng)謹(jǐn)慎使用全局混入,因?yàn)樗鼤?huì)影響每個(gè)單獨(dú)創(chuàng)建的 Vue 實(shí)例 (包括第三方組件)。大多數(shù)情況下,只應(yīng)當(dāng)應(yīng)用于自定義選項(xiàng),就像上面示例一樣。推薦將其作為插件發(fā)布,以避免重復(fù)應(yīng)用混入。

$forceUpdate


功能: 迫使 Vue 實(shí)例重新渲染。
用法:

vm.$forceUpdate()

說(shuō)明: 注意它僅僅影響實(shí)例本身和插入插槽內(nèi)容的子組件,而不是所有子組件。

set、delete


功能: 對(duì)響應(yīng)式數(shù)據(jù)的屬性進(jìn)行設(shè)置、刪除,同時(shí)觸發(fā)視圖更新。
用法:

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

說(shuō)明:

  • target:目標(biāo)對(duì)象
  • key:要添加的屬性名
  • value:要添加的屬性值

ps:主要使用場(chǎng)景,可以避開(kāi) Vue 不能檢測(cè)到 property 被刪除的限制

filter


功能: 用于一些常見(jiàn)的文本格式化和一些規(guī)范數(shù)據(jù)mapping。
用法:

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

說(shuō)明:

  • 過(guò)濾器函數(shù)總接收表達(dá)式的值 (之前的操作鏈的結(jié)果) 作為第一個(gè)參數(shù)。
  • 過(guò)濾器應(yīng)該被添加在 JavaScript 表達(dá)式的尾部,由“管道”符號(hào)指示。

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

directive


功能: 用于注冊(cè)自定義指令。
用法:

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

說(shuō)明:

  • inserted 只是注冊(cè)指令的其中一個(gè)插值函數(shù),完整的注冊(cè)屬性還可以包括:
    • bind:只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,在這里可以進(jìn)行一次性的初始化設(shè)置。
    • inserted:被綁定元素插入父節(jié)點(diǎn)時(shí)調(diào)用(僅保證父節(jié)點(diǎn)存在,但不一定已被插入文檔中)。
    • update:所在組件的 VNode 更新時(shí)調(diào)用,但是可能發(fā)生在其子 VNode 更新之前。指令的值可能發(fā)生了改變,也可能沒(méi)有,但是可以通過(guò)比較更新前后的值來(lái)忽略不必要的模板更新。
    • componentUpdated:指令所在組件的 VNode 及其子 VNode 全部更新后調(diào)用。
    • unbind:只調(diào)用一次,指令與元素解綁時(shí)調(diào)用。
Vue.directive('my-directive', {   bind: function () {},   inserted: function () {},   update: function () {},   componentUpdated: function () {},   unbind: function () {} })

v-model 語(yǔ)法糖

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

v-model 是一個(gè)語(yǔ)法糖,可以拆解為 props: value 和 events: input。就是說(shuō)組件必須提供一個(gè)名為 value 的 prop,以及名為 input 的自定義事件,滿足這兩個(gè)條件,使用者就能在自定義組件上使用 v-model。比如下面的示例,實(shí)現(xiàn)了一個(gè)數(shù)字選擇器:

<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 一般不能在組件內(nèi)修改,它是通過(guò)父級(jí)修改的,因此實(shí)現(xiàn) v-model 一般都會(huì)有一個(gè) currentValue 的內(nèi)部 data,初始時(shí)從 value 獲取一次值,當(dāng) value 修改時(shí),也通過(guò) watch 監(jiān)聽(tīng)到及時(shí)更新;組件不會(huì)修改 value 的值,而是修改 currentValue,同時(shí)將修改的值通過(guò)自定義事件 input 派發(fā)給父組件,父組件接收到后,由父組件修改 value。所以,上面的數(shù)字選擇器組件可以有下面兩種使用方式:

<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 這兩個(gè)名字,從 Vue.js 2.2.0 版本開(kāi)始,提供了一個(gè) model 的選項(xiàng),可以指定它們的名字,所以數(shù)字選擇器組件也可以這樣寫(xiě):

<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 選項(xiàng)里,就可以指定 prop 和 event 的名字了,而不一定非要用 value 和 input,因?yàn)檫@兩個(gè)名字在一些原生表單元素里,有其它用處。

.sync 修飾符

如果你使用過(guò) Vue.js 1.x,一定對(duì) .sync 不陌生。在 1.x 里,可以使用 .sync 雙向綁定數(shù)據(jù),也就是父組件或子組件都能修改這個(gè)數(shù)據(jù),是雙向響應(yīng)的。在 Vue.js 2.x 里廢棄了這種用法,目的是盡可能將父子組件解耦,避免子組件無(wú)意中修改了父組件的狀態(tài)。

不過(guò)在 Vue.js 2.3.0 版本,又增加了 .sync 修飾符,但它的用法與 1.x 的不完全相同。2.x 的 .sync 不是真正的雙向綁定,而是一個(gè)語(yǔ)法糖,修改數(shù)據(jù)還是在父組件完成的,并非在子組件。

仍然是數(shù)字選擇器的示例,這次不用 v-model,而是用 .sync,可以這樣改寫(xiě):

<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>

看起來(lái)要比 v-model 的實(shí)現(xiàn)簡(jiǎn)單多,實(shí)現(xiàn)的效果是一樣的。v-model 在一個(gè)組件中只能有一個(gè),但 .sync 可以設(shè)置很多個(gè)。.sync 雖好,但也有限制,比如:

  • 不能和表達(dá)式一起使用(如 v-bind:title.sync="doc.title + '!'" 是無(wú)效的);

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

其它簡(jiǎn)單的常用屬性和方法

// console.log(vm.$root);  vm.$root    //實(shí)例對(duì)象  vm.$el  //根元素(真實(shí)的DOM元素) // console.log(vm.$el);  vm.$el.innerHTML    //得到根元素(真實(shí)的DOM元素)中的內(nèi)容 // console.log(vm.$el.innerHTML);  vm.$data    //實(shí)例下的data對(duì)象 // console.log(vm.$data);  vm.$options     //實(shí)例下的掛載項(xiàng) // console.log(vm.$options);  vm.$props   //組件之間通信的數(shù)據(jù) // console.log(vm.$props);  vm.$parent      //在組件中,指父元素 // console.log(vm.$parent);  vm.$children    //在組件中,指子代元素 // console.log(vm.$children);  vm.$attrs   //用來(lái)獲取父組件傳遞過(guò)來(lái)的所有屬性 // console.log(vm.$attrs);  vm.$listeners   //用來(lái)獲取父組件傳遞過(guò)來(lái)的所有方法 // console.log(vm.$listeners);  vm.$slots   //組件中的插槽 // console.log(vm.$slots);  vm.$scopedSlots     //用來(lái)訪問(wèn)作用域插槽 // console.log(vm.$scopedSlots);  vm.$refs    //用來(lái)定位DOM元素(使用ref進(jìn)行追蹤) // console.log(vm.$refs);  vm.$watch   //用于監(jiān)聽(tīng)數(shù)據(jù)(在vue文件中使用后會(huì)自動(dòng)銷毀) // console.log(vm.$watch);  vm.$emit    //用于派發(fā)事件(常用于數(shù)據(jù)通信) // console.log(vm.$emit);  vm.$on  //用于監(jiān)聽(tīng)事件的派發(fā) // console.log(vm.$on);  vm.$once    //只監(jiān)聽(tīng)事件一次(之后不監(jiān)聽(tīng)) // console.log(vm.$once);  //生命周期 beforeCreate() { } created() { } beforeMount() { } mounted() { } beforeUpdate() { } updated() { } beforeDestroy() { } destroyed() { }

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

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
男女猛烈激情XX00免费视频| 国产日韩精品SUV| 成人午夜亚洲精品无码区毛片| 成人午夜精品无码区| 国产精品国产三级国产专I| 国产毛片一二区三区四区 | 人妻大战黑人白浆狂泄| 日韩无码视频一区二区三区四区| 挺进绝色校花的紧窄小肉| 亚洲AⅤ中文无码字幕色本草| 亚洲嫩草AV永久无码精品天堂| 伊人久久大香线焦AV色| 99无码人妻一区二区三区免费| 波多野结衣迅雷种子| 国产激情久久久久影院| 经典精品毛片免费观看| 毛片无码中文字幕| 日韩AV无码一区二区三区不卡| 无码人妻精品一区二区蜜桃天美| 亚洲国产激情一区二区三区| 精品少妇爆乳无码AⅤ区| 久久精品国产亚洲AV果冻传媒| 免费高清曰韩仑理| 日韩 无码 偷拍 中文字幕| 午夜国产精品一二三区无码小说| 亚洲色大成网站WWW在线| 99久久无码一区人妻| 国产成人AV一区二区三区不卡 | 巨爆乳中文字幕巨爆区巨爆乳无码| 欧美老熟妇XOXOXOⅩO| 色哟哟网站在线观看入口| 亚洲成AV人片在线观看无下载| 中文字幕人妻被公上司喝醉| 得到超级肉禽系统的小说怎么办| 好男人日本社区WWW| 男友把舌头都伸进我的嘴巴里了| 少妇被粗大的猛进出69影院| 亚洲男人第一无码AV网站| GAY男同帅哥网站在线观看| 国产精品成人无码久久久| 久久久久精品老熟女国产精品| 日本精品少妇一区二区三区| 亚洲国产成人精品福利在线观看 | 乱色精品无码一区二区国产盗| 日本熟妇色丰满少妇wwwww色| 亚洲A成人片在线播放| AV人摸人人人澡人人超碰| 国产高清一区二区三区视频| 久久夜色精品国产噜噜噜亚洲AV | 高清拍拍拍无挡国产精品| 精品视频无码一区二区三区| 人妻丰满妇岳av无码区HD| 亚洲VA无码VA在线VA天堂| 八戒八戒在线高清观看视频4| 韩国三级在线观看| 人妻激情偷乱视频一区二区三区| 亚洲xxx色色精选| XX娇小嫩XX中国XX| 精品国产第一福利网站| 黄a无码片内射无码视频| 琪琪午夜伦伦电影理论片| 亚洲成AⅤ人片在线观看天堂无码 亚洲成AⅤ人片久青草影院 | 亚洲精品一区二区三浪潮AV| 成在人线AV无码免费| 久久夜色撩人精品国产AV| 无码国产精品一区二区免费式影视| 中国熟妇色XXXXX| 国产三级A三级三级| 破外女第一次出血毛片免费| 亚洲区激情区无码区| 国产成人精品久久综合| 蜜桃AV自慰久久久久免费网站| 亚洲AV无码AV在线播放| 宝贝腿开大一点你真湿H| 久久国产精品99久久人人澡| 熟女亚洲综合精品伊人久久| 999ZYZ玖玖资源站永久| 精品无码久久久久久午夜| 天天天天躁天天爱天天碰2018| 97久章草在线视频播放| 教官在我腿间疯狂驰聘视频| 少妇肉欲小说200篇| 97成人碰碰久久人人超级碰OO| 互换人妻ⅩXXBBBB| 特黄熟妇丰满人妻无码| 99久久99久久精品免费看蜜桃| 精品无码一区二区三区水蜜桃| 无码精品久久久久久人妻中字| 啊灬啊灬啊灬快灬高潮了霸总 | 永久亚洲成A人片777777| 国产亚洲欧美日韩精品一区二区| 久草玖玖玖爱在线资源| 我和大佬的365天| 暗呦交小U女国产精品视频| 麻豆人妻少妇精品无码专区| 亚洲国产精品无码一线岛国 | 久久久WWW成人免费精品| 亚洲AⅤ成人精品无码| 国产ZLJZLJZLJZLJ| 日本免码VA在线看免费最新 | 亚洲乱色伦图片区小说| 国产女人水真多18毛片18精品 | 免费韩国漫画网站观看| 亚洲午夜无码久久久久小说| 国产尤物亚洲精品不卡| 无码AV免费一区二区三区四区| 成年女人18毛片毛片免费不卡| 欧美黑人XXXX| 18禁男女爽爽爽午夜网站免费| 久久综合给合久久国产免费| 亚洲老熟女XXXXHDWAA| 国产专区一线二线三线品牌| 无线乱码A区B区C区D| 国产成人综合一区人人| 涩爱亚洲色欲AV无码成人专区| 把腿张开老子臊烂你的动漫| 热RE99久久精品国产99热| FREEZEFRAME丰满寡妇| 女朋友特别闷骚很吸引别人 | 内射后入在线观看一区| 18禁黄无遮挡网站免费高清| 六个人玩我一个人| 亚洲线精品一区二区三区影音先锋| 黑人疯狂巨大XXⅩ0O0| 亚洲AV中文无码乱人伦APP| 国产在线无码一区二区三区| 亚洲AV成人片无码网站网8X| 国产亚洲成AⅤ人片在线观看麻豆 国产亚洲成AⅤ人片在线观看 | 精人妻无码一区二区三区蜜桃 | 无码成人一区二区三区| 国产精品久久久一区二区三区| 无码喷水一区二区浪潮AV| 国产裸体歌舞一区二区| 性欧美ⅩXXXX极品少妇| 国色天香精品一卡2卡3卡老狼| 亚洲成a人片在线观看无码专区 | 欧洲熟妇色XXXXⅩ欧美老妇天| WWWXXX国产| 日韩欧无码一二三区免费不卡| 丰满熟女高潮毛茸茸欧洲视频| 天堂AⅤ无码一区二区三区| 国产精品扒开腿做爽爽爽| 无遮挡边吃奶边做的视频刺激 | 乖我们换个姿态再来一遍吧的小说 | 9精产国品一二三产区| 人妻人妇人妻一区二区三区| 成人视频在线观看| 我半夜摸妺妺的奶摸到高潮 | 老师抱着我在教室做| 18禁美女黄网站色大片免费观看 | 久久天天躁夜夜躁狠狠躁 | 亚洲成AV人片一区二区| 久久久久久久久久精品电影 | 亚洲AV无码一区二区三区天堂| 久久精品国产2020观看福利| 主人调教下贱的烂货| 日本高清视频www| 国产成人无码区免费A∨视频网站 国产成人无码免费视频在线 | 精品一区二区三区不卡少妇av| 稚嫩的花苞被老师开了| 欧洲人激情毛片无码视频| 刺激交换经历过程小说| 校花内裤被涂满了强烈春药| 久久精品AⅤ无码中文字字幕蜜桃| 中文精品久久久久人妻| 人人爽人人澡人人人人妻| 国产极品美女高潮无套APP| 亚洲AV中文无码乱人伦在线观看 | 制服 丝袜 人妻 专区一本| 人妻少妇乱子伦无码视频专区| 国产成人欧美一区二区三区| 亚洲精品国产AV现线| 免费网站看V片在线18禁| 第二书包网高H肉辣文| 亚洲AV无码成人精品涩涩| 乱人伦中文无码视频| 成人欧美一区二区三区白人| 小受呻吟高潮GV在线观看| 久久天天躁狠狠躁夜夜网站 | 日本高清无卡码一区二区久久 | 麻豆文化传媒精品一区观看| 成熟丰满女人丰满妇女aⅴ| 亚洲AV日韩精品久久久久久A| 蜜臀AV午夜福利一区二区三区| 抽搐一进一出再深一点| 亚洲丰满熟妇浓毛XXXX| 农村岳的肥白大腚| 国产精东天美AV影业传媒| 亚洲色欲久久久久综合网| 欧亚成年男女深夜百度网盘| 国产免费又爽又色又粗视频| 影音先锋亚洲AV少妇熟女| 三妻四妾免费观看完整版高清| 极品丰满熟妇人妻无码| 91人妻人人做人碰人人爽蜜闫| 铜铜铜铜铜铜铜好-深色| 久久综合国产乱子伦精品免费| 绯色精品人妻av一区二区| 亚洲性无码AV在线| 十八款夜间禁用APP|