欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于怎么在vue項目里寫react詳情

 更新時間:2021年09月17日 15:40:21   作者:greet_eason  
本篇文章是在vue項目里寫tsx的一篇介紹。其實vue里面寫jsx也挺有意思的,接下來小編九給大家詳細介紹吧,感興趣的小伙伴請參考下面的文章內(nèi)容

我們可以直接創(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)文章

  • vue3插槽:el-table表頭插入tooltip及更換表格背景色方式

    vue3插槽:el-table表頭插入tooltip及更換表格背景色方式

    這篇文章主要介紹了vue3插槽:el-table表頭插入tooltip及更換表格背景色方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Vue3+Vite項目使用mockjs隨機模擬數(shù)據(jù)

    Vue3+Vite項目使用mockjs隨機模擬數(shù)據(jù)

    這篇文章主要介紹了Vue3+Vite項目使用mockjs隨機模擬數(shù)據(jù),需要的朋友可以參考下
    2023-01-01
  • Vue+Element?switch組件的使用示例代碼詳解

    Vue+Element?switch組件的使用示例代碼詳解

    這篇文章主要介紹了Vue+Element?switch組件的使用,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • vue中遇到scrollIntoView無效問題及解決

    vue中遇到scrollIntoView無效問題及解決

    這篇文章主要介紹了vue中遇到scrollIntoView無效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 基于vue實現(xiàn)圖片驗證碼倒計時60s功能

    基于vue實現(xiàn)圖片驗證碼倒計時60s功能

    這篇文章主要介紹了基于vue實現(xiàn)圖片驗證碼倒計時60s功能,本文通過截圖實例代碼的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • vuex使用方法超詳細講解(實用)

    vuex使用方法超詳細講解(實用)

    這篇文章主要給大家介紹了關(guān)于vuex使用方法的相關(guān)資料,主要內(nèi)容包括Vuex的安裝和配置,以及如何在.vue文件中引入和使用Vuex狀態(tài),作者還分享了一種在模塊中存儲狀態(tài)的建議方法,并提供了具體的代碼示例,需要的朋友可以參考下
    2024-10-10
  • vue3一個元素如何綁定兩個或多個事件

    vue3一個元素如何綁定兩個或多個事件

    這篇文章主要介紹了vue3一個元素如何綁定兩個或多個事件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue自動路由-單頁面項目(非build時構(gòu)建)

    vue自動路由-單頁面項目(非build時構(gòu)建)

    這篇文章主要介紹了vue自動路由-單頁面項目(非build時構(gòu)建),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • vue項目的訪問端口及其設(shè)置方式

    vue項目的訪問端口及其設(shè)置方式

    這篇文章主要介紹了vue項目的訪問端口及其設(shè)置方式,具有很好的參考價值,希望對大家有所幫助。
    2022-10-10
  • Vue高性能列表GridList組件及實現(xiàn)思路詳解

    Vue高性能列表GridList組件及實現(xiàn)思路詳解

    這篇文章主要為大家介紹了Vue高性能列表GridList組件及實現(xiàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11

最新評論