關(guān)于怎么在vue項目里寫react詳情
我們可以直接創(chuàng)建jsx/tsx文件
這次的項目結(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這么寫
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>
}
}
在來看一下頁面

可能有心者注意到了 我還引用了一個CreateElement,這是干嘛的呢。這玩意叫渲染函數(shù)。不喜歡讀vue那么大串的文檔的兄弟看這里。簡單解釋:這個東西可以渲染一個vnode節(jié)點。它比模板更接近編譯器。什么意思呢?意思就是模板語法也會編譯成渲染函數(shù)。所以我們直接用渲染函數(shù)不就相當(dāng)于節(jié)省了模板語法到渲染函數(shù)的過程。四舍五入項目性能又是一個大的提升!
簡單介紹一下傳參:
第一個參數(shù): {String | Object | Function} 一個 HTML 標(biāo)簽名、組件選項對象,或者 resolve 了上述任何一種的一個 async 函數(shù)。必填項。
第二個參數(shù): Object 一個與模板中 attribute 對應(yīng)的數(shù)據(jù)對象。
第三個參數(shù): {String | Array} 文本節(jié)點或子級虛擬節(jié)點 (VNodes)。
渲染函數(shù)給vue帶來了很多的靈活性,以前你想自定義在子組件里插入東西,得寫一大堆的插槽<slot> 。有了渲染函數(shù)我們可以這么玩。
// 改造一下上面的index.vue的data
private list = [
{ render: () => ["a", { style: { color: "red" } }, "我要去淘寶"] },
{ render: () => ["a", { style: { color: "green" } }, "我要去京東"] },
{ render: () => ["a", { style: { color: "pink" } }, "我要去百度"] },
];
tsx中這么寫:
{
this.opt.map((it) => {
return h(...it.render())
})
}
就可以渲染出花里胡哨的頁面了

我們還可以這么玩:
// tsx改造
<span>
{
this.opt.map((it) => {
return it.render(h)
})
}
</span>
在index.vue頁面我們就可以這么玩:
// 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項目里寫react詳情的文章就介紹到這了,更多相關(guān)在vue項目里寫react內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot+Vue開發(fā)之Login校驗規(guī)則、實現(xiàn)登錄和重置事件
這篇文章主要介紹了SpringBoot+Vue開發(fā)之Login校驗規(guī)則、實現(xiàn)登錄和重置事件,本文通過圖文實例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
vue數(shù)據(jù)傳遞--我有特殊的實現(xiàn)技巧
這篇文章主要介紹了vue數(shù)據(jù)傳遞一些特殊梳理技巧,需要的朋友可以參考下2018-03-03
Vue實現(xiàn)英文字母大小寫在線轉(zhuǎn)換功能
在Web開發(fā)中,字符串處理是常見的需求之一,特別是在國際化應(yīng)用中,對于文本的格式化處理尤為重要,本文將介紹如何使用Vue.js來構(gòu)建一個簡單的在線英文字母大小寫轉(zhuǎn)換工具,需要的朋友可以參考下2024-09-09

