Vue3.0與Vue2.0對比(一)

  • 讀了Vue3.0beta 文檔,對原有的方法静陈、屬性與2.x不同的地方做了對比,記錄下來做成表格,分享出來
  • 計劃分為5期發(fā)布赴邻,前期主要是分享差異與新特性的使用,最后的兩期會深入分析與實(shí)現(xiàn)vue3.0響應(yīng)式實(shí)現(xiàn)原理
  • 表格中的 阿拉伯?dāng)?shù)字 為注解肌幽,在文章開頭開頭注解
  • 正文開始贪庙,不到之處請留下您寶貴意見

  • ⅰ:vm = Vue.createApp({}) || new Vue({}) Vue實(shí)例化對象
  • ⅱ:全局方法 component directive mixin mount use provide
  • ⅲ:生命周期 beforeCreate, created, beforeMount, mounted, beforeUpdate, updated, activated, deactivated, beforeDestroy, destroyed,errorCaptured

API / Func名稱 Vue3 Vue2.x
全局掛載屬性/方法 vm.confi.globalProperties.xxx = xxx Vue.prototype.xxx = xxx
自定義元素 vm.config.isCustomElement = tag => tag.startWith('str-') Vue.config.ignoredElements = [
'my-custom-web-component',
'another-web-component',
/^str-/
]
合并策略 vm.config.optionsMergeStrategies.hello = (toVal, fromVal, vm) => {
Vue.config.optionMergeStrategies.myOption =
function (toVal, fromVal) {// 返回合并后的值}
全局方法 所有的全局方法掛載在 vm實(shí)例 中而不在提供靜態(tài)方法
提供了全局注入方法provide(key, value)
提供了解除掛載方法 unmount(ele)
所有全局方法是Vue構(gòu)造函數(shù)的靜態(tài)方法
實(shí)例化 Vue.createApp({}) new Vue({})
實(shí)例化參數(shù) Object Object
實(shí)例化傳入props Vue.createApp({props: ['propA']}, {propA: 'a'}) const Comp = Vue.extend(comp)
new Comp({propsData: {}})
定義一個組件 import {defineComponent} from 'vue'
const Comp = defineComponent({})
const Comp = Vue.component('name', {})
異步組件 import {defineAsyncComponent} from 'vue'
asyncComp: defineAsyncComponent(
() => import(componentPath)
)
asyncComp: () => import(componentPath)
nextTick import {createApp, nextTick } from 'vue'
vm.$nextTick()
生命周期
添加了renderTracked(vnode 第一次渲染的時候 debug用),
renderTriggered(vnode 重新轉(zhuǎn)染的時候 debug用)
beforeDestroy 變?yōu)?beforeUNmount
destroyed 變?yōu)?unmounted
mixins 無變化 無變化
extends 無變化 無變化

新特性

  • resolveComponent

如果組件在當(dāng)前應(yīng)用程序?qū)嵗锌捎猛帕蓿瑒t允許按其名稱解析組件育拨。
如果找不到組件,返回組件或undefined 欢摄。

const app = Vue.createApp({})
app.component('MyComponent', {
  /* ... */
})

import { resolveComponent } from 'vue'
render() {
  const MyComponent = resolveComponent('MyComponent')
}

返回值: component

  • resolveDynamicComponent

允許使用<component:is="">使用的相同機(jī)制來解析組件熬丧。
返回解析的組件或以組件名稱作為節(jié)點(diǎn)標(biāo)記的新創(chuàng)建的VNode。如果未找到該組件怀挠,將發(fā)出警告析蝴。
不太理解什么意思,等下次再補(bǔ)充

import { resolveDynamicComponent } from 'vue'
render () {
  const MyComponent = resolveDynamicComponent('MyComponent')
}

resolveComponent, resolveDynamicComponent只能在渲染函數(shù)或函數(shù)組件中使用绿淋。

  • resolveDirective

如果指令在當(dāng)前應(yīng)用程序?qū)嵗锌捎妹苹瑒t允許按其名稱解析指令。
返回一個指令或undefined

const app = Vue.createApp({})
app.directive('highlight', {})

import { resolveDirective } from 'vue'
render () {
  const highlightDirective = resolveDirective('highlight')
}
  • withDirectives

允許應(yīng)用指令到一個VNode吞滞。返回一個帶有應(yīng)用指令的VNode佑菩。

import { withDirectives, resolveDirective } from 'vue'
const foo = resolveDirective('foo')
const bar = resolveDirective('bar')
return withDirectives(h('div'), [
  [foo, this.x],
  [bar, this.y],
  [directive, value],
  [directive, value, arg, modifiers]
  // 指令名盾沫, 指令值, 參數(shù)殿漠, 修飾符
  ...
])

未完待續(xù)赴精。。绞幌。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蕾哟,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子啊奄,更是在濱河造成了極大的恐慌渐苏,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件菇夸,死亡現(xiàn)場離奇詭異琼富,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)庄新,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門鞠眉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人择诈,你說我怎么就攤上這事械蹋。” “怎么了羞芍?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵哗戈,是天一觀的道長。 經(jīng)常有香客問我荷科,道長唯咬,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任畏浆,我火速辦了婚禮胆胰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘刻获。我一直安慰自己蜀涨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布蝎毡。 她就那樣靜靜地躺著厚柳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪沐兵。 梳的紋絲不亂的頭發(fā)上草娜,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機(jī)與錄音痒筒,去河邊找鬼宰闰。 笑死茬贵,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的移袍。 我是一名探鬼主播解藻,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼葡盗!你這毒婦竟也來了螟左?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤觅够,失蹤者是張志新(化名)和其女友劉穎胶背,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體喘先,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡钳吟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了窘拯。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片红且。...
    茶點(diǎn)故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖涤姊,靈堂內(nèi)的尸體忽然破棺而出暇番,到底是詐尸還是另有隱情,我是刑警寧澤思喊,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布壁酬,位于F島的核電站,受9級特大地震影響恨课,放射性物質(zhì)發(fā)生泄漏厨喂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一庄呈、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧派阱,春花似錦诬留、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至腺劣,卻和暖如春绿贞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背橘原。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工籍铁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涡上,地道東北人。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓拒名,卻偏偏與公主長得像吩愧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子增显,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評論 2 355