在Vue2和Vue3中JSX的使用集錦

来源:https://www.cnblogs.com/observer-csh/archive/2023/09/12/17688837.html
-Advertisement-
Play Games

Vue2安裝JSX支持 有時候,我們使用渲染函數(render function)來抽象組件,而渲染函數使用Vue的h函數來編寫Dom元素相對template語法差別較大,體驗不佳,這個時候就派 JSX 上場了。然而在Vue3中預設是帶了JSX支持的,而在 Vue2 中使用 JSX,需要安裝並使用 ...


Vue2安裝JSX支持

有時候,我們使用渲染函數(render function)來抽象組件,而渲染函數使用Vue的h函數來編寫Dom元素相對template語法差別較大,體驗不佳,這個時候就派 JSX 上場了。然而在Vue3中預設是帶了JSX支持的,而在 Vue2 中使用 JSX,需要安裝並使用 Babel 插件:

  • @vue/babel-preset-jsx
  • @vue/babel-helper-vue-jsx-merge-props

安裝腳本

npm install @vue/babel-preset-jsx @vue/babel-helper-vue-jsx-merge-props

配置.babelrc文件

module.exports = {
  presets: [
    '@vue/cli-plugin-babel/preset',
    ['@vue/babel-preset-jsx',
      {
        'injectH': false
      }]
  ]
}

template和JSX的使用差異

針對方向

vue2中template語法和jsx語法差異

變數綁定

變數綁定由data中的數據由 v-model="value"變為 v-model={this.value}

template語法

<el-input v-model="value" />

JSX語法

<el-input v-model={this.value} />

事件綁定

變數綁定由data中的數據由 @input="inputChange"或v-on:input="inputChange"變為 onInput={this.inputChange}或on-input={this.inputChange}

template語法

<el-input v-model="value" @input="inputChange" v-on:click="inputClick" />

JSX語法

<el-input v-model={this.value} onInput={this.inputChange} on-click={this.inputClick} />

條件渲染

條件渲染由 v-if變為插入JSX 語句段

template語法

<el-input v-model="value" v-if="show" @input="inputChange" v-on:click="inputClick" />

JSX語法

{
	if(this.show){
		return <el-input v-model={this.value} onInput={this.inputChange} on-click={this.inputClick} />
	}
}

列表渲染

變數綁定由data中的數據由 v-for變為插入JSX 語句段

template語法

<el-select v-model={this.form.formula} clearable>
    <el-option
    	v-for="item in options"
       :key="item.value"
       :label="item.label"
       :value="item.label">
      </el-option>
</el-select>

JSX語法

<el-select v-model={this.form.formula} clearable>
    {
        this.options.map(item =>{
            return (
                <el-option
                 key={item.value}
                 label={item.label}
                 value={item.value}>
                </el-option>
            )
        }
    
    }
</el-select>

插槽的使用

命名插槽

組件名稱:BaseLayout
template語法

<div class="container">
  <header>
 	<!-- 具名插槽  -->
    <slot name="header"></slot>
  </header>
  <main>
  	<!-- 匿名插槽  -->
    <slot></slot>
    <!-- 作用域插槽  -->
    <slot :main="mainData"></slot>
  </main>
  
  <footer>
  	<!-- 具名插槽  -->
    <slot name="footer"></slot>
  </footer>
</div>

JSX語法
註意:$slots在Vue2.6版本起才支持,在之前使用的是$slotScopeds

<div class="container">
  <header>
    {
    	//具名插槽
    	this.$slots.header
    }
  </header>
  <main>
    {
    	//匿名插槽
    	this.$slots.default
    }
    {
    	//作用域插槽
       () => this.$slots.main(this.mainData)
    }
  </main>
  <footer>
    {
    	//具名插槽
    	this.$slots.footer
    }
  </footer>
</div>

使用插槽

template語法

<base-layout>
  <template #header>
  	<div>我是頭部</div>
  </template>
  <template #default>
  	<div>匿名插槽</div>
  </template>
  <!-- vue2.6之後使用方式 -->
  <template #main="mainData">
  	<div>作用域插槽:{{mainData}}</div>
  </template>
  <!-- vue2.6之前使用 -->
  <template slot="main" slot-scope="mainData">
  	<div>作用域插槽:{{mainData}}</div>
  </template>
  <template #footer>
  	<div>具名插槽</div>
  </template>
</base-layout>

JSX語法

<!-- vue2.6之後使用方式 -->
<base-layout>
	{{
      default: () => <div>匿名插槽</div>,
      header: () => <div>我是頭部</div>,
      main: (mainData) => <div>作用域插槽:{mainData}</div>,
      footer: () => <div>具名插槽</div>
    }}
</base-layout>
<!-- vue2.6之前使用方式 -->
<base-layout
	slotScoped={{
      default: () => <div>匿名插槽</div>,
      header: () => <div>我是頭部</div>,
      main: (mainData) => <div>作用域插槽:{mainData}</div>,
      footer: () => <div>具名插槽</div>
    }}>	
</base-layout>

JSX中el-form

el-form需要綁定通過props={{ model:this.form}}來綁定form對象,不能使用model={this.form} ,否則就會出現報錯Invalid handler for event “input“: got undefined

render(h){
    return (
	    <el-form
	        ref="elForm"
	        class="rule-form"
	        props={{ model:this.form}} >
	    </el-form>
    )
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Intel 海光 鯤鵬920 飛騰2500 CPU性能對比 為了讓程式能快點,特意瞭解了CPU的各種原理,比如多核、超線程、NUMA、睿頻、功耗、GPU、大小核再到分支預測、cache_line失效、加鎖代價、IPC等各種指標(都有對應的代碼和測試數據)都會在這系列文章中得到答案。當然一定會有程式員 ...
  • 1. ENUM(枚舉) 1.1. MySQL在存儲枚舉時非常緊湊,會根據列表值的數量壓縮到1或者2位元組中 1.2. 轉換為ENUM會使表變小 1.3. 如果表中有其他索引,減少主鍵大小也會使這些非主鍵索引小得多 1.4. ENUM列可以存儲一組預定義的不同字元串值 1.5. ENUM欄位是根據內部整 ...
  • 1. Redis的數據結構有哪些 1. 字元串(String):字元串是Redis最基本的數據結構。它可以存儲任意類型的數據,包括文本、整數或二進位數據。字元串類型的值最大可以達到512MB。 SET name "John" GET name ``` 將字元串"John"存儲在鍵名為"name"的字 ...
  • Apache DolphinScheduler 是一款開源的分散式任務調度系統,旨在幫助用戶實現複雜任務的自動化調度和管理。DolphinScheduler 支持多種任務類型,可以在單機或集群環境下運行。下麵將介紹如何實現 DolphinScheduler 的自動化打包和單機/集群部署。 自動化打包 ...
  • 1、表名:應體現具體業務含義,全部小寫,多個單詞下劃線分割。 2、欄位:欄位名應體現具體業務含義,全部小寫、多個單詞下劃線分割,選擇合適的數據類型,並且加註釋 每個表應具有以下公共欄位: 欄位名 欄位類型 欄位說明 id int(11)/bigint(20) 自增主鍵id create_user_i ...
  • 在第14屆中國資料庫技術大會(DTCC2023)上,華為雲資料庫運維研發總監李東詳細解讀了GaussDB運維繫統自動駕駛探索和實踐。 ...
  • SQL文件鏈接在最下麵 MySQL子查詢相關使用 子查詢的實質:一個 select 語句的查詢結果能夠作為另一個語句的輸入值。子查詢不僅可用於 where 子句中,還能夠用於 from 子句中,此時子查詢的結果將作為一個臨時表(temporary table)來使用。 一、 單行子查詢 1、 查詢“ ...
  • 引言 Apple MDM (Mobile Device Management) 字面理解就是一種管理移動設備的方式,覆蓋 iOS 5 及更高版本的 iPhone/iPod touch/iPad、Mac OS X 10.7 及更高版本的 Mac、TVOS 9 及更高版本的 Apple TV,標題中的 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...