vue3+tsx的使用

handlebars 复制代码
<template>
    <div>
    <xiaoman @on-click="getItem" name="似懂非懂"></xiaoman>
    </div>
</template>
  
<script setup lang='ts'>
  import  xiaoman  from  "./App"
  const  getItem=(item:any)=>{
    console.log(item,'item')
  }
</script>
  
<style>
  
</style>
javascript 复制代码
// 返回一个渲染函数
// optionsApi
// setup 函数模式
// ref  template  自动解包.value tsx并不会 ref.value
// v-if不支持  三元表达式去代替v-if
// map 去代替v-for
// v-bind {}代替
// props emit
// 插槽
const A = (slots: any) => (<>
    <div>{slots.default?slots.default:"默认值" }</div>
    <div>{slots.foo?.()}</div>
</>)
interface Props{
    name?:string
}
import { defineComponent,ref } from "vue";
export default defineComponent({
    props: {
        name:String
    },
    emits:['on-click'],
    setup(props:Props,{emit}) {
        const flag = ref(false);
        const data = [
            {
                name:"小满1"
            },
            {
                name:"小满2"
            },
            {
                name:"小满3"
            }
        ]

        const fn = (item:any) => {
            console.log(item, "触发了");
            emit("on-click",item)
        }

        const slot = {
            default: () => (<div>小满default slots</div>),
            foo:()=>(<div>小满foo slots  </div>)
        }
        return () => (<>
            <A v-slots={slot}></A>
            <hr />
            <div> props:{props?.name}</div>
            <hr />
            {
                data.map(v => {
                    return <div onClick={()=>fn(v)}>{ v.name}</div>
                })
            }</>)
    }
    // data(){
    //     return {
    //         age:23
    //     }
    // },
    // render (){
    //     return (<div>{ this.age}</div>)
    // }
}) 

效果图:

相关推荐
恋猫de小郭4 分钟前
Android Studio Panda 2 ,支持 AI 用 Vibe Coding 创建项目
android·前端·flutter
爱学习的程序媛6 分钟前
【Web前端】WebSocket 详解
前端·websocket·网络协议·web
BJ-Giser7 分钟前
Cesium夜晚月亮银河夜空效果
前端·可视化·cesium
happymaker06268 分钟前
web前端学习日记——DAY06(js基础语法与数据类型)
前端·javascript·学习
FlyWIHTSKY8 分钟前
父子组件参数传递
前端·javascript·vue.js
不会写DN9 分钟前
JS 最常用的性能优化 防抖和节流
开发语言·javascript·ecmascript
紫_龙16 分钟前
最新版vue3+TypeScript开发入门到实战教程之生命周期函数
前端·javascript·typescript
小江的记录本24 分钟前
【反射】Java反射 全方位知识体系(附 应用场景 + 《八股文常考面试题》)
java·开发语言·前端·后端·python·spring·面试
孟陬25 分钟前
国外技术周刊 #4:这38条阅读法则改变了我的人生、男人似乎只追求四件事……
前端·人工智能·后端
工边页字26 分钟前
cursor接上figma mcp ,图形图像模式傻瓜式教学(包教包会版)
前端·人工智能·ai编程