电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Vue常用API、高級API的相關總結

瀏覽:12日期:2022-10-06 18:00:17

最近手癢癢,玩兒了一下Vue3.0,很舒服,趕緊把這幾期Vue2.0弄完,寫一些3.0的東西。本文主要羅列和解析一些個人認為常用或有大用途的Api,作為自我總結的筆記和探討。

nextTick

功能:

添加在下次Dom更新循環結束之后的延遲回調,修改數據之后,可以獲取更新后的Dom。用法:

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

說明:

callback:延遲回調函數context:可選的objectps: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

功能:

對響應式數據的屬性進行設置、刪除,同時觸發視圖更新。用法:

// 用法1Vue.set( target, key, value )Vue.delete( target, key )// 用法2vm.$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 () {}})其它簡單的常用屬性和方法

// 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,如果有興趣學習更多,可以參考其官網。希望本文對你有用,并能熟練運用到實際的項目開發中。

為了方便閱讀理解,本文代碼已經上傳Github

文中如有錯誤,歡迎在評論區指正,如果有所幫助,歡迎點贊和關注。

以上就是Vue常用API、高級API的相關總結的詳細內容,更多關于Vue常用API、高級API的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 发电机价格|发电机组价格|柴油发电机价格|柴油发电机组价格网 | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 混合气体腐蚀试验箱_盐雾/硫化氢/气体腐蚀试验箱厂家-北京中科博达 | 湖州织里童装_女童男童中大童装_款式多尺码全_织里儿童网【官网】-嘉兴嘉乐网络科技有限公司 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 液压扳手-高品质液压扳手供应商 - 液压扳手, 液压扳手供应商, 德国进口液压拉马 | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 导电银胶_LED封装导电银胶_半导体封装导电胶厂家-上海腾烁 | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | 成都中天自动化控制技术有限公司| 风信子发稿-专注为企业提供全球新闻稿发布服务 | 流程管理|流程管理软件|企业流程管理|微宏科技-AlphaFlow_流程管理系统软件服务商 | 南溪在线-南溪招聘找工作、找房子、找对象,南溪综合生活信息门户! | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | 变压器配件,变压器吸湿器,武强县吉口变压器配件有限公司 | 上海平衡机-单面卧式动平衡机-万向节动平衡机-圈带动平衡机厂家-上海申岢动平衡机制造有限公司 | 低气压试验箱_高低温低气压试验箱_低气压实验箱 |林频试验设备品牌 | 361°官方网站| 合肥花魁情感婚姻咨询中心_挽回爱情_修复婚姻_恋爱指南 | 真空泵厂家_真空泵机组_水环泵_旋片泵_罗茨泵_耐腐蚀防爆_中德制泵 | 蓝鹏测控平台 - 智慧车间系统 - 车间生产数据采集与分析系统 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 酵素生产厂家_酵素OEM_酵素加盟_酵素ODM_酵素原料厂家_厦门益力康 | 上海道勤塑化有限公司| 工作服定制,工作服定做,工作服厂家-卡珀职业服装(苏州)有限公司 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 房屋质量检测-厂房抗震鉴定-玻璃幕墙检测-房屋安全鉴定机构 | 医用空气消毒机-医用管路消毒机-工作服消毒柜-成都三康王 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 蒜肠网-动漫,二次元,COSPLAY,漫展以及收藏型模型,手办,玩具的新媒体.(原变形金刚变迷TF圈) | 出国劳务公司_正规派遣公司[严海]| 真空搅拌机-行星搅拌机-双行星动力混合机-广州市番禺区源创化工设备厂 | 深圳活动策划公司|庆典策划|专业公关活动策划|深圳艺典文化传媒 重庆中专|职高|技校招生-重庆中专招生网 | 智能门锁电机_智能门锁离合器_智能门锁电机厂家-温州劲力智能科技有限公司 | 南京泽朗生物科技有限公司-液体饮料代加工_果汁饮料代加工_固体饮料代加工 | 山东led显示屏,山东led全彩显示屏,山东LED小间距屏,临沂全彩电子屏-山东亚泰视讯传媒有限公司 | YT保温材料_YT无机保温砂浆_外墙保温材料_南阳银通节能建材高新技术开发有限公司 |