您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)如何在vue中使用props,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
1. 數(shù)組形式
props: ['name', 'value']
2. 對象形式
對象形式內(nèi)部也提供了三種寫法:
props: { // 基礎(chǔ)的類型檢查 name: String, // 多個可能的類型 value: [String, Number], // 對象形式 id: { type: Number, required: true } }
props實(shí)現(xiàn)的原理
function normalizeProps (options: Object, vm: ?Component) { const props = options.props if (!props) return const res = {} let i, val, name if (Array.isArray(props)) { ... } else if (isPlainObject(props)) { ... } else if (process.env.NODE_ENV !== 'production') { ... } options.props = res }
normalizeProps 函數(shù)就是vue實(shí)際處理 props 的地方,從函數(shù)名的翻譯我們可以看出該函數(shù)的功能就是標(biāo)準(zhǔn)化 props 的值。該函數(shù)主要分成3部分:① 從 options 對象中獲取 props 的值并且定義一個res空對象;②幾個 if ... else ,分別根據(jù) props 值的不同類型來處理 res 對象;③ 用處理后的 res 對象覆蓋原來 options 對象的 props 屬性的值。
接下來看看那幾個 if ... else 的代碼:
if (Array.isArray(props)) { i = props.length while (i--) { val = props[i] if (typeof val === 'string') { name = camelize(val) res[name] = { type: null } } else if (process.env.NODE_ENV !== 'production') { warn('props must be strings when using array syntax.') } } }
這個代碼實(shí)際就是處理props的值為數(shù)組的情況,例如: props: ['name', 'value'] 。使用while遍歷該數(shù)組,如果數(shù)組內(nèi)元素的類型不是字符串并且不是生產(chǎn)環(huán)境,那么就拋錯:‘props的值類型為數(shù)組時,數(shù)組里面的元素的類型就必須是字符串'。如果是字符串的情況下,使用 camelize 函數(shù)處理一下 val 的值,并且賦值給 name 變量。這里的 camelize 函數(shù)的實(shí)際作用就是將 '-' 轉(zhuǎn)換為駝峰。 camelize 函數(shù)具體的實(shí)現(xiàn)方式在后面分析。然后在 res 對象上面添加一個為 name 變量的屬性,該屬性的值為空對象 { type: null } 。
props: ['name', 'value'] 這種寫法經(jīng)過上面的處理后就會變成了下面這樣:
props: { name: { type: null }, value: { type: null } }
接下來看看下面這個 else if(isPlainObject(props)) ,這里的 isPlainObject 函數(shù)實(shí)際就是返回 props 的值是否為 object , isPlainObject 函數(shù)的具體實(shí)現(xiàn)我們也在后面分析。
else if (isPlainObject(props)) { for (const key in props) { val = props[key] name = camelize(key) res[name] = isPlainObject(val) ? val : { type: val } } }
使用 for...in 遍歷props對象,和上面一樣使用 camelize 函數(shù)將 '-' 轉(zhuǎn)換為駝峰。這里有個三目運(yùn)算:
res[name] = isPlainObject(val) ? val : { type: val }
判斷了一下 val 如果是 object ,那么在res對象上面添加一個為name變量的屬性,并且將該屬性的值設(shè)置為val。這個其實(shí)就是處理下面這種props的寫法:
props: { // 對象形式 id: { type: Number, required: true } }
如果 val 不是 object ,那么也在res對象上面添加一個為name變量的屬性,并且將該屬性的值設(shè)置為{ type: val }。這個其實(shí)就是處理下面這種props的寫法:
props: { // 基礎(chǔ)的類型檢查 name: String, // 多個可能的類型 value: [String, Number], }
經(jīng)過處理后props會變成了下面這樣:
props: { name: { type: String }, value: { type: [String, Number] } }
所以不管我們使用vue提供的 props 哪種寫法,最終vue都會幫我們轉(zhuǎn)換成下面這種類型:
props: { name: { ..., type: '類型' } }
接下來看看上面提到的util函數(shù) isPlainObject ,先把源碼貼出來。
const _toString = Object.prototype.toString export function isPlainObject (obj: any): boolean { return _toString.call(obj) === '[object Object]' }
其實(shí) Object.prototype.toString.call(obj) 的值為obj對象的類型。例如:
Object.prototype.toString.call({a: 1}) // [object Object] Object.prototype.toString.call(new Date) // [object Date] Object.prototype.toString.call([1]) // [object Array] Object.prototype.toString.call(null) // [object Null]
接下來看看上面提到的util函數(shù) camelize ,還是先把源碼貼出來。
export function cached<F: Function> (fn: F): F { const cache = Object.create(null) return (function cachedFn (str: string) { const hit = cache[str] return hit || (cache[str] = fn(str)) }: any) } const camelizeRE = /-(\w)/g export const camelize = cached((str: string): string => { return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : '') })
這里定義了兩個函數(shù),分別是 cached 和 camelize ,其中 camelize 就是我們上面調(diào)用的, cached 是在 camelize 函數(shù)內(nèi)部調(diào)用的。
我們先來看看 camelize 函數(shù),其實(shí) camelize 函數(shù)就是執(zhí)行 cached 后返回的一個函數(shù)。調(diào)用 cached 時傳入了一個箭頭函數(shù),箭頭函數(shù)內(nèi)部是調(diào)用了正則的 replace 方法,將傳入的 str 變量中匹配 /-(\w)/g 的變成大寫字母,并且返回 replace 后的值。(也就是將 - 轉(zhuǎn)換成駝峰)。
再來看看 cached 函數(shù),該函數(shù)傳入的變量其實(shí)就是 camelize 那里的箭頭函數(shù),首先定義了一個 cache 空對象,然后直接返回了 cachedFn 函數(shù)。我們在外部調(diào)用 camelize(key) 時,其實(shí)就是執(zhí)行了這里的了 cachedFn 函數(shù), str 的值就是傳入的 key 的值。很明顯這里是一個閉包,可以在外部調(diào)用 camelize 函數(shù)的時候可以修改或者讀取這里定義的 cache 對象的值。獲取 cache 對象中 key 為 str 變量值的屬性值賦值給 hit 變量。如果有hit變量的值,那么就直接返回hit的值,如果沒有就執(zhí)行 camelize 傳入的箭頭函數(shù),并且將箭頭函數(shù)的返回值賦值給 catche 對象的 str 屬性。如果下次調(diào)用 camelize 函數(shù)時傳入了相同的 str ,那么就不會執(zhí)行箭頭函數(shù),直接返回閉包中的 cache 對象的 str 屬性的值。這里是性能優(yōu)化的一種手段。
例如:第一次調(diào)用 camelize('name') 后, cache 對象的值就變成了{(lán)name: 'name'}。然后在其他地方再次調(diào)用 camelize('name') 時再次執(zhí)行 cachedFn 函數(shù),此時 hit 變量的值為'name'。直接返回 hit 變量的值,不會執(zhí)行傳入的箭頭函數(shù)。
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫只關(guān)注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫開發(fā)復(fù)雜的單頁應(yīng)用。
看完上述內(nèi)容,你們對如何在vue中使用props有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。