摘要:函數(shù)通過來創(chuàng)建你的。什么情況下適合使用函數(shù)在一次封裝一套通用按鈕組件的工作中,按鈕有四個(gè)樣式。遇上類似這樣的情況,使用函數(shù)可以說最優(yōu)選擇了。根據(jù)實(shí)際情況改寫按鈕組件首先函數(shù)生成的內(nèi)容相當(dāng)于的內(nèi)容,故使用函數(shù)時(shí),在文件中需要先把標(biāo)簽去掉。
render函數(shù)
vue通過 template 來創(chuàng)建你的 HTML。但是,在特殊情況下,這種寫死的模式無法滿足需求,必須需要js的編程能力。此時(shí),需要用render來創(chuàng)建HTML。
什么情況下適合使用render函數(shù)在一次封裝一套通用按鈕組件的工作中,按鈕有四個(gè)樣式(success、error、warning、default)。首先,你可能會(huì)想到如下實(shí)現(xiàn)
{{ text }}{{ text }}{{ text }}
這樣寫在按鈕樣式少的時(shí)候完全沒有問題,但是試想,如果需要的按鈕樣式有十多個(gè)。那么template寫死的方式就顯得很無力了。遇上類似這樣的情況,使用render函數(shù)可以說最優(yōu)選擇了。
根據(jù)實(shí)際情況改寫按鈕組件首先render函數(shù)生成的內(nèi)容相當(dāng)于template的內(nèi)容,故使用render函數(shù)時(shí),在.vue文件中需要先把template標(biāo)簽去掉。只保留邏輯層。
export default { props: { type: { type: String, default: "normal" }, text: { type: String, default: "normal" } }, computed: { tag() { switch (this.type) { case "success": return 1; case "danger": return 2; case "warning": return 3; default: return 1; } } }, render(h) { return h("div", { class: { btn: true, "btn-success": this.type === "success", "btn-danger": this.type === "danger", "btn-warning": this.type === "warning" }, domProps: { innerText: this.text }, on: { click: this.handleClick } }); }, methods: { handleClick() { console.log("-----------------------"); console.log("do something"); } } };
根據(jù)組件化思維,能抽象出來的東西絕不寫死在邏輯上。這里的clickHandle函數(shù)可以根據(jù)按鈕的type類型觸發(fā)不同的邏輯,就不多敘述了。
然后在父組件調(diào)用
使用jsx是的,要記住每個(gè)參數(shù)的類型同用法,按序傳參實(shí)在是太麻煩了。那么其實(shí)可以用jsx來優(yōu)化這個(gè)繁瑣的過程。
render() { return ({this.text}); },
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/53054.html
摘要:源碼是選用了作為,看的源碼時(shí)發(fā)現(xiàn)對(duì)應(yīng)了不同的構(gòu)建選項(xiàng)。這也對(duì)應(yīng)了最后打包構(gòu)建后產(chǎn)出的不同的包。第四種構(gòu)建方式對(duì)應(yīng)的構(gòu)建腳本為不同于前面種構(gòu)建方式這一構(gòu)建對(duì)應(yīng)于將關(guān)于模板編譯的成函數(shù)的單獨(dú)進(jìn)行打包輸出。 Vue源碼是選用了rollup作為bundler,看Vue的源碼時(shí)發(fā)現(xiàn):npm script對(duì)應(yīng)了不同的構(gòu)建選項(xiàng)。這也對(duì)應(yīng)了最后打包構(gòu)建后產(chǎn)出的不同的包。 不同于其他的library,V...
摘要:原文鏈接我的,歡迎。這次想要分享的一篇文章是從一個(gè)奇怪的錯(cuò)誤出發(fā)理解的基本概念。瞬間明白了,原來是函數(shù),一個(gè)考驗(yàn)編程能力的函數(shù),比更接近編譯器。來看這里有一個(gè)小知識(shí)點(diǎn)被忽略在實(shí)例掛載之后,元素可以用訪問腦補(bǔ)會(huì)用到的場景中。。。 原文鏈接我的blog,歡迎STAR。 這次想要分享的一篇文章是:從一個(gè)奇怪的錯(cuò)誤出發(fā)理解Vue的基本概念。 這篇文章以Vue的兩種構(gòu)建方式做為切入點(diǎn),深入探討...
摘要:函數(shù)通過參數(shù)來創(chuàng)建虛擬,結(jié)構(gòu)精簡。其中,訪問的用法,使用場景集中在函數(shù)。使用代替模板功能在函數(shù)中,不再需要內(nèi)置的指令,比如。方法時(shí)快速改變數(shù)組結(jié)構(gòu),返回一個(gè)新數(shù)組。 學(xué)習(xí)筆記:Render函數(shù) Render函數(shù) Vue2與Vue1最大的區(qū)別就在于Vue2使用了虛擬DOM來更新DOM節(jié)點(diǎn),提升渲染性能。 Vue2與Vue1最大的區(qū)別就在于Vue2使用了虛擬DOM來更新DOM節(jié)點(diǎn),提升...
摘要:圖在中應(yīng)用三數(shù)據(jù)渲染過程數(shù)據(jù)綁定實(shí)現(xiàn)邏輯本節(jié)正式分析從到數(shù)據(jù)渲染到頁面的過程,在中定義了一個(gè)的構(gòu)造函數(shù)。一、概述 vue已是目前國內(nèi)前端web端三分天下之一,也是工作中主要技術(shù)棧之一。在日常使用中知其然也好奇著所以然,因此嘗試閱讀vue源碼并進(jìn)行總結(jié)。本文旨在梳理初始化頁面時(shí)data中的數(shù)據(jù)是如何渲染到頁面上的。本文將帶著這個(gè)疑問一點(diǎn)點(diǎn)追究vue的思路。總體來說vue模版渲染大致流程如圖1所...
摘要:的構(gòu)造函數(shù)將自動(dòng)運(yùn)行啟動(dòng)函數(shù)。我在閱讀源碼的過程中,發(fā)現(xiàn)源碼余行,而和模板編譯相關(guān)的代碼,則約有行左右。這個(gè)是創(chuàng)建的方法,作為第一個(gè)參數(shù)傳入。最后會(huì)返回一個(gè)節(jié)點(diǎn)。這個(gè)時(shí)候?qū)①x值為這個(gè)節(jié)點(diǎn),掛載完成 mount, 意思為掛載。可以理解為將vue實(shí)例(邏輯應(yīng)用),掛靠在某個(gè)dom元素(載體)上的一個(gè)過程。 一、創(chuàng)建Vue實(shí)例時(shí)的渲染過程 上一篇文章我們講到, 在創(chuàng)建一個(gè)vue實(shí)例的時(shí)候(v...
摘要:通過的合并策略合并添加項(xiàng)到新的構(gòu)造器上緩存父構(gòu)造器處理和相關(guān)響應(yīng)式配置項(xiàng)在新的構(gòu)造器上掛上的工具方法緩存組件構(gòu)造器在上總的來說是返回了一個(gè)帶有附加配置相的新的的構(gòu)造器。在函數(shù)中,構(gòu)造器叫做,等待時(shí)候初始化。 身為原來的jquery,angular使用者。后面接觸了react和vue。漸漸的喜歡上了vue。抱著學(xué)習(xí)的態(tài)度呀。看看源碼。果然菜要付出代價(jià)。一步步單步調(diào)試。頭好疼。看到哪里記到...
閱讀 3105·2021-10-15 09:41
閱讀 3176·2021-09-22 16:05
閱讀 2416·2021-09-22 15:19
閱讀 2879·2021-09-02 15:11
閱讀 2455·2019-08-30 15:52
閱讀 844·2019-08-30 11:06
閱讀 1008·2019-08-29 16:44
閱讀 1261·2019-08-23 18:18