關(guān)于怎么在vue項(xiàng)目里寫(xiě)react詳情
我們可以直接創(chuàng)建jsx/tsx文件
這次的項(xiàng)目結(jié)構(gòu)是這樣的:
在vue文件里這么使用
// index.vue <template> <div class="wrapper"> <Common :opt="list" /> </div> </template> <script lang="ts"> import { Component, Vue } from "vue-property-decorator"; import Common from "./components/Common"; @Component({ name: "App", components: { Common, }, }) export default class App extends Vue { private list = ["我要去淘寶", "我要去百度", "我要去京東"]; } </script>
tsx這么寫(xiě)
import { CreateElement } from 'vue'; import { Component, Vue, Prop } from 'vue-property-decorator'; @Component({ name: 'Common' }) export default class Common extends Vue { @Prop(Object) opt!: any[] render(h: CreateElement) { return <span> { this.opt.map((it) => { return <span style="marginRight:10px">{it}</span> }) } </span> } }
在來(lái)看一下頁(yè)面
可能有心者注意到了 我還引用了一個(gè)CreateElement
,這是干嘛的呢。這玩意叫渲染函數(shù)。不喜歡讀vue那么大串的文檔的兄弟看這里。簡(jiǎn)單解釋?zhuān)哼@個(gè)東西可以渲染一個(gè)vnode
節(jié)點(diǎn)。它比模板更接近編譯器。什么意思呢?意思就是模板語(yǔ)法也會(huì)編譯成渲染函數(shù)。所以我們直接用渲染函數(shù)不就相當(dāng)于節(jié)省了模板語(yǔ)法到渲染函數(shù)的過(guò)程。四舍五入項(xiàng)目性能又是一個(gè)大的提升!
簡(jiǎn)單介紹一下傳參:
第一個(gè)參數(shù): {String
| Object
| Function
} 一個(gè) HTML 標(biāo)簽名、組件選項(xiàng)對(duì)象,或者 resolve
了上述任何一種的一個(gè) async 函數(shù)。必填項(xiàng)。
第二個(gè)參數(shù): Object
一個(gè)與模板中 attribute
對(duì)應(yīng)的數(shù)據(jù)對(duì)象。
第三個(gè)參數(shù): {String
| Array
} 文本節(jié)點(diǎn)或子級(jí)虛擬節(jié)點(diǎn) (VNodes
)。
渲染函數(shù)給vue帶來(lái)了很多的靈活性,以前你想自定義在子組件里插入東西,得寫(xiě)一大堆的插槽<slot>
。有了渲染函數(shù)我們可以這么玩。
// 改造一下上面的index.vue的data private list = [ { render: () => ["a", { style: { color: "red" } }, "我要去淘寶"] }, { render: () => ["a", { style: { color: "green" } }, "我要去京東"] }, { render: () => ["a", { style: { color: "pink" } }, "我要去百度"] }, ];
tsx中這么寫(xiě):
{ this.opt.map((it) => { return h(...it.render()) }) }
就可以渲染出花里胡哨的頁(yè)面了
我們還可以這么玩:
// tsx改造 <span> { this.opt.map((it) => { return it.render(h) }) } </span> 在index.vue頁(yè)面我們就可以這么玩: // index.vue private list = [ { render: (h: CreateElement) => h("a", { style: { color: "red", marginRight: "5px" } }, "我要去淘寶"), }, { render: (h: CreateElement) => h("a", { style: { color: "green", marginRight: "5px" } }, "我要去京東"), }, { render: (h: CreateElement) => h("a", { style: { color: "pink", marginRight: "5px" } }, "我要去百度"), }, ];
結(jié)果也是同樣的花哨
我們同樣可以渲染亂七八糟的標(biāo)簽!
// index.vue改造 { render: (h: CreateElement) => h( "h1", { style: { color: "green", marginRight: "5px" }, }, "我要去京東" ), },
我們可以隨心所欲的在渲染函數(shù)中定義事件:
// index.vue private list = [ { render: (h: CreateElement) => h( "a", { style: { color: "red", marginRight: "5px" }, on: { click: () => this.iWillGoWhere("TB"), }, }, "我要去淘寶" ), }] iWillGoWhere(type: string) { const goWhere: any = { TB: () => { alert("我要去淘寶!"); }, JD: () => { alert("我要去京東!"); }, BD: () => { alert("我要去百度!"); }, }; goWhere[type](); }
這樣就可以啦!
到此這篇關(guān)于關(guān)于怎么在vue項(xiàng)目里寫(xiě)react詳情的文章就介紹到這了,更多相關(guān)在vue項(xiàng)目里寫(xiě)react內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue3中reactive函數(shù)toRef函數(shù)ref函數(shù)簡(jiǎn)介
- 手摸手教你實(shí)現(xiàn)Vue3 Reactivity
- Vue3.0中Ref與Reactive的區(qū)別示例詳析
- Vue3中ref與reactive的詳解與擴(kuò)展
- 詳解vue3中setUp和reactive函數(shù)的用法
- vue3組合API中setup、 ref、reactive的使用大全
- 詳解React Angular Vue三大前端技術(shù)
- Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比
- Vue和React有哪些區(qū)別
- vue與react詳細(xì)
相關(guān)文章
vue3插槽:el-table表頭插入tooltip及更換表格背景色方式
這篇文章主要介紹了vue3插槽:el-table表頭插入tooltip及更換表格背景色方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06Vue3+Vite項(xiàng)目使用mockjs隨機(jī)模擬數(shù)據(jù)
這篇文章主要介紹了Vue3+Vite項(xiàng)目使用mockjs隨機(jī)模擬數(shù)據(jù),需要的朋友可以參考下2023-01-01vue中遇到scrollIntoView無(wú)效問(wèn)題及解決
這篇文章主要介紹了vue中遇到scrollIntoView無(wú)效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05基于vue實(shí)現(xiàn)圖片驗(yàn)證碼倒計(jì)時(shí)60s功能
這篇文章主要介紹了基于vue實(shí)現(xiàn)圖片驗(yàn)證碼倒計(jì)時(shí)60s功能,本文通過(guò)截圖實(shí)例代碼的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12vue3一個(gè)元素如何綁定兩個(gè)或多個(gè)事件
這篇文章主要介紹了vue3一個(gè)元素如何綁定兩個(gè)或多個(gè)事件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11vue自動(dòng)路由-單頁(yè)面項(xiàng)目(非build時(shí)構(gòu)建)
這篇文章主要介紹了vue自動(dòng)路由-單頁(yè)面項(xiàng)目(非build時(shí)構(gòu)建),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04vue項(xiàng)目的訪問(wèn)端口及其設(shè)置方式
這篇文章主要介紹了vue項(xiàng)目的訪問(wèn)端口及其設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。2022-10-10Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解
這篇文章主要為大家介紹了Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11