Vue3进阶<2>插槽在tsx 语法的使用

Vue3进阶<2>插槽在tsx 语法的使用

tsx语法

Vue3的TSX语法是一种在Vue组件中使用TypeScript编写代码的方法。TSX是JSX的扩展,它允许我们在Vue模板中使用类似于HTML的标记来描述组件的结构,tsx 语法在封装一些组件的时候有很大的用途

1.vite构建项目中使用 安装配置

bash 复制代码
npm i -D @vitejs/plugin-vue-jsx

2.配置 vite.coonfig.ts

typescript 复制代码
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import vueJsx from '@vitejs/plugin-vue-jsx';
 
// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue(), vueJsx({})],
});

3.配置tsconfig.json

json 复制代码
{
  "compilerOptions": {
    "jsx": "preserve",
    "jsxFactory": "h",
    "jsxFragmentFactory": "Fragment",
  }
}

tsx 语法的介绍请参考官网

tsx中使用插槽

vue3中,新增了 defineComponent ,它并没有实现任何的逻辑,只是把接收的 Object 直接返回,它的存在是完全让传入的整个对象获得对应的类型,它的存在就是完全为了服务 TypeScript 而存在的。

setup 函数默认接收两个参数 1. props 2. ctx 上下文 其中包含 slots、attrs、emit 等

子组件children.tsx

typescript 复制代码
import { defineComponent,reactive } from 'vue'
export default defineComponent({
    setup(props, { slots }) {
        const state = reactive({
            name:"周杰伦",
            phone: "15888888888"
        })
        return () => (
            <div>
                <p>我是子组件</p>
                {/* 这是默认插槽 */}
                {
                    slots.default ? slots.default() : null
                }
                {/* 这是具名插槽 */}
                {
                    slots. sex ? slots. sex() : null
                }
                {/* 这是作用域插槽 */}
                {
                    slots.fullInfo ? slots.fullInfo({ name: state.name, phone:state.phone}) : null
                }
            </div>
        );
    }
})

父组件

typescript 复制代码
import Children  from './components/children.tsx';
import {defineComponent} from 'vue'
export default defineComponent({
    setup() {
        return () => (
            <div class={'box'}>
                <Children>
                    {{
                        default: () => <p>年龄18</p>,
                        sex: () => <p>男</p>,
                        fullInfo(slotProps) {
                            return [
                                <p>{slotProps.name}</p>,
                                <p>{slotProps.phone}</p>,
                            ];
                        }
                    }}
                </Children>
            </div>
        );
    }
})

页面效果

v-slots 指令

除了直接在组件中传递包含插槽函数的对象外,还可以通过 v-slots 指令传递,这样就可以将插槽内容单独抽取出来

typescript 复制代码
import Children  from './components/children.tsx';
import {defineComponent} from 'vue'
export default defineComponent({
    setup() {
        const slots = {
            default: () => <p>年龄18</p>,
            sex: () => <p>男</p>,
            fullInfo(slotProps) {
                return [
                    <p>{slotProps.name}</p>,
                    <p>{slotProps.phone}</p>,
                ];
            }
        }
        return () => (
            <div class={'box'}>
                <Children v-slots={slots}/>
            </div>
        );
    }
})

这样,结构和数据就进行了分离,看着更加干净清晰,也便于我们后期的维护。

当然,默认插槽也可以标签的形式直接写在组件里,就像这样:

typescript 复制代码
return () => (
    <div class={'box'}>
        <p>我是父组件1</p>
        <Children v-slots={slots}/>
    </div>
);

页面效果

这里需要指出的是,在 Vue 官方文档中,并没有 v-slots 这个指令,我们之所以能在 TSX 中使用它是因为项目中安装了 @vitejs/plugin-vue-jsx 插件,该插件允许以 JSX 的方式来编写 Vue 代码。

相关推荐
xinyu_Jina6 分钟前
Calculator Game:WebAssembly在计算密集型组合优化中的性能优势
前端·ui·性能优化
JustHappy9 分钟前
「2025年终个人总结」🤬🤬回答我!你个菜鸟程序员这一年发生了啥?
前端
BD_Marathon9 分钟前
Vue3_计算属性
javascript·vue.js·ecmascript
啃火龙果的兔子21 分钟前
可以指定端口启动本地前端的npm包
前端·npm·node.js
new code Boy30 分钟前
前端base-64 编码解码
前端·javascript·html
前端摸鱼匠37 分钟前
Vue 3 的watch监听多个数据源:讲解如何同时监听多个响应式数据的变化
前端·javascript·vue.js·前端框架·ecmascript
文心快码BaiduComate40 分钟前
用Spec给AI Agent立规矩,AI编码告别手忙脚乱
前端·后端·前端框架
东北小狐狸-Hellxz41 分钟前
后端生成的URL中含base64参数值,经tomcat重定向后偶发前端无法解密报错
java·前端·tomcat
hssfscv1 小时前
Javeweb学习笔记——Vue+Ajax
vue.js·笔记·学习·ajax
在等星星呐1 小时前
人工智能从0基础到精通
前端·人工智能·python