在Vue2和Vue3中JSX的使用集锦

这篇具有很好参考价值的文章主要介绍了在Vue2和Vue3中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和Vue3中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文章来源地址https://www.toymoban.com/news/detail-707989.html

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

到了这里,关于在Vue2和Vue3中JSX的使用集锦的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 为什么有时候ADSL访问速度会很慢

      为什么有时候ADSL访问速度会很慢        1.网卡绑定的协议太多。上网速度慢,在局域网用户中很常见,原因是网卡绑定的协议太多。网卡上如果绑定了许多协议,当数据通过网卡时,计算机就要花费很多时间来确定这个数据使用哪种协议来传送,这时用户就会感觉上网慢

    2024年02月08日
    浏览(53)
  • M330左键有时候按下没反应的解决 - 换微动

    罗技M330鼠标左键有时候按下没反应,原因是微动老了要换新的了。 1、电烙铁/锡条(最主要的是这两个,其他可以不需要,操作电烙铁时候一定要小心,不要碰到被烫到) 2、小号螺丝刀,给眼镜用的那种,用来拆鼠标的螺丝(共2个螺丝) 视频教程: https://www.bilibili.com/vi

    2024年02月09日
    浏览(55)
  • jsx (vue3项目中使用)

    一、什么是jsx 在 JavaScript 里面写 HTML 的语法,就叫做 JSX,算是对 JavaScript 语法的一个扩展. (在vue3项目中相当于单文件组件,.vue)使用的是jsx语法 二、jsx语法 1.插值。与 vue 模板语法中的插值一样,但是双大括号 {{}} 变为了单大括号 {}。大括号内支持任何有效的 JavaScript 表

    2024年01月17日
    浏览(42)
  • Vue3 项目中怎么使用 jsx——易懂

    在 vue3 项目中使用JSX( JavaScript XML )可以让你更灵活地创建组件和视图。接下来给大家讲解一下vue3项目中怎么使用 jsx 步骤 1: 创建一个Vue 3 项目 如果你还没有Vue 3项目,可以使用Vue CLI来创建一个。 在创建项目时,确保选择Vue 3选项。接下来,进入项目目录并启动开发服务器

    2024年02月06日
    浏览(36)
  • 如何在 vue3 中使用 jsx/tsx?

    我们都知道,通常情况下我们使用 vue 大多都是用的 SFC(Signle File Component)单文件组件模式,即一个组件就是一个文件,但其实 Vue 也是支持使用 JSX 来编写组件的。这里不讨论 SFC 和 JSX 的好坏,这个仁者见仁智者见智。本篇文章旨在带领大家快速了解和使用 Vue 中的 JSX 语法,好让大家

    2023年04月19日
    浏览(49)
  • vue3中的excel表导出功能(选中导出或导出所有,也可支持vue2)

    1.安装模块 npm install xlsx file-saver -S 2.文件导入 import * as XLSX from \\\"xlsx\\\"; import FileSaver from \\\"file-saver\\\" 3.整体代码(可选中导出或导出所有) id绑定表格全部导出 4.效果如下        

    2024年02月17日
    浏览(45)
  • 在Android Studio导入一个项目之后,通常需要下载Gradle的相应版本,但是AS的自动下载很慢,有时候甚至会失败。会出现类似Error:connect time out等错误...

    用Android Studio导入一个项目时,用Gradle构建过程中报错误,估计是下载gradle.zip文件时访问不到,应该是被墙了,网速太慢,下载不了外网资源。错误有如下情况:1、加载过慢2、下载超时3、下载失败 解决方法如下: 1、下载对应的gradle版本 在Project的视图下,找到gradle,里面的

    2024年02月03日
    浏览(81)
  • vue去掉所有输入框两边空格,封装指令去空格,支持Vue2和Vue3,ElementUI Input去空格

    就是页面很多表单输入框,期望在提交的时候,都要把用户两边的空格去掉 ❌使用 vue 的指令 .trim 去掉空格 中间会输入不了空格, 比如我想输入 你好啊 中国 , 这中间的空格输入不了,只能变成 你好啊中国 ❌在提交的时候使用 trim() 方法去两边空格 需要一个个字段的添加,

    2024年02月14日
    浏览(49)
  • VSCode使用background-cover插件后弹出“code安装似乎损坏,请重新安装“,有时顶部显示“不受支持“--解决方法

    最近在使用vscode的时候发现有时候右下角会弹出\\\"code安装似乎损坏,请重新安装\\\",顶部显示\\\"不受支持\\\"的问题。  经过排查,发现是background-cover这个插件的问题,原因应该是通过这个插件去给vscode设置自定义图片作为背景的时候修改了vscode本身的配置文件,导致了vscode认为安装

    2024年02月09日
    浏览(85)
  • mac安装nodejs,vue2, vue3

    Error: You are using macOS 11.7. We do not provide support for this pre-release version. You will encounter build failures with some formulae. Please create pull requests instead of asking for help on Homebrew’s GitHub, Twitter or any other official Mac 使用brew 安装工具报错 Your CLT does not support macOS 11https://zhuanlan.zhihu.com/p/462517486 安

    2024年02月10日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包