【vue3】jsx文件编写函数式组件

1.创建HelloWord.jsx文件

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    return () => (
      <>
        <div>helloWord</div>
      </>
    )
  }
})
export default helloWord

2.Dom上使用ref变量

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    const account = ref(1)
    setInterval(() => {
      account.value = account.value + 1
    }, 1000)
    return () => (
      <>
        <div>helloWord{account.value}</div>
      </>
    )
  }
})
export default helloWord

3.遍历、条件渲染

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    const list = ["一", "二", "三", "四", "五"]
    const show = ref(false)
    function onSwitch() {
      show.value = !show.value
    }
    return () => (
      <>
        <div>
          <label>遍历渲染</label>
          {/* 遍历渲染 */}
          {list.map((item, index) => {
            return <li key={index}>{item}</li>
          })}
        </div>
        <div>
          <label>条件渲染</label>
          {/* 条件渲染 */}
          {show.value && <div>helloWord</div>}
          {/* 三目运算 */}
          {show.value ? <div>helloWord</div> : <div>hide</div>}
        </div>
        <button onClick={onSwitch}>显示/隐藏文本</button>
      </>
    )
  }
})
export default helloWord

4、事件绑定

(1)简单绑定

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    const show = ref(false)
    function onSwitch() {
      show.value = !show.value
    }
    return () => (
      <>
        <div>
          <label>条件渲染</label>
          {/* 条件渲染 */}
          {show.value && <div>helloWord</div>}
          {/* 三目运算 */}
          {show.value ? <div>helloWord</div> : <div>hide</div>}
        </div>
        <button onClick={onSwitch}>显示/隐藏文本</button>
      </>
    )
  }
})
export default helloWord

(2)事件修饰符

对于 .passive.capture 和 .once 事件修饰符,可以使用驼峰写法将他们拼接在事件名后面:

<button
  onClickCapture={() => {}}
  onKeyupOnce={() => {}}
  onMouseoverOnceCapture={() => {}}
/>

对于事件和按键修饰符,可以使用 withModifiers 函数: 

import { defineComponent } from "vue"
import { withModifiers } from "vue"

const helloWord = defineComponent({
  setup() {
    return () => (
      <>
        {/* 等价于 v-on:click.stop.prevent */}
        <button onClick={withModifiers(() => {}, ["stop", "prevent"])}>按钮</button>
      </>
    )
  }
})
export default helloWord

5、Class 与 Style 绑定

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    const className = "className"
    return () => (
      <>
        <div class={className}></div>
        <div
          style={{
            background: "red"
          }}
        >
          背景色
        </div>
      </>
    )
  }
})
export default helloWord

6、使用自定义组件

import { defineComponent } from "vue"

const helloWord = defineComponent({
  setup() {
    return () => (
      <>
        <ButtonCustom count={10} onChange={() => {}} />
      </>
    )
  }
})
export default helloWord

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue2中使用JSX编写组件是一种替代模板语法的方法。使用JSX可以更直观地描述组件结构和逻辑,使代码更加可读性和可维护性。可以通过配置Babel插件来实现将JSX转译为render函数渲染。 下面是一个使用JSX编写Vue2组件的示例: ```jsx export default { name: 'MyComponent', data() { return { options: [ { value: 'option1', label: 'Option 1' }, { value: 'option2', label: 'Option 2' }, { value: 'option3', label: 'Option 3' } ], selectedOption: '' } }, render() { return ( <div class="my-component"> {this.options.map(option => ( <div key={option.value} class={option.value === this.selectedOption ? 'selected' : ''} onClick={() => (this.selectedOption = option.value)} > {option.label} </div> ))} </div> ) } } ``` 在上面的示例中,我们使用JSX语法来描述组件的结构,通过render函数JSX转译为渲染函数。可以看到,使用JSX可以更直观地创建组件,并且可以通过JSX语法来处理组件的交互逻辑。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue+jsx函数组件](https://blog.csdn.net/weixin_41923266/article/details/126661795)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue组件jsx语法的具体使用](https://download.csdn.net/download/weixin_38607908/13207182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值