组件的声明、创建、渲染

在Vue 3中,有多种方法来声明、创建和渲染组件。以下是全面的总结:

  1. 组件声明方法:
typescript 复制代码
// 选项式API
export default defineComponent({
  props: {},
  setup() {}
})

// 组合式API
export default {
  setup() {}
}

// <script setup>语法糖
<script setup>
// 直接编写逻辑
</script>

// 传统的类组件
export default class MyComponent extends Vue {}
  1. 组件创建方法:
typescript 复制代码
// 普通组件
const MyComponent = defineComponent({})

// 函数式组件
const FunctionalComponent: FunctionalComponent = (props, ctx) => {
  return h('div', props.text)
}

// 动态组件
const componentsMap = {
  ComponentA,
  ComponentB
}
  1. 组件渲染方式:
vue 复制代码
<!-- 模板渲染 -->
<template>
  <MyComponent />
  <component :is="dynamicComponent" />
</template>

<!-- 动态渲染 -->
<script setup>
import { h, resolveComponent } from 'vue'

// 渲染方式1:h()函数
const VNode = h(MyComponent, { props })

// 渲染方式2:渲染函数
render() {
  return h('div', [
    h(MyComponent),
    h(resolveComponent('el-button'))
  ])
}

// 渲染方式3:动态组件
const currentComponent = shallowRef(ComponentA)
</script>

<!-- 异步组件 -->
<script setup>
import { defineAsyncComponent } from 'vue'

const AsyncComponent = defineAsyncComponent(() => 
  import('./components/MyComponent.vue')
)
</script>

<!-- 内置组件渲染 -->
<component :is="tabs[currentTab]" />
  1. 高级组件创建:
typescript 复制代码
// 高阶组件
function withLoading(Component) {
  return {
    setup() {
      const loading = ref(true)
      return () => h(Component, { loading })
    }
  }
}

// 泛型组件
interface Props<T> {
  data: T[]
}
function GenericComponent<T>(props: Props<T>) {
  return h('div', props.data)
}
  1. 渲染控制:
vue 复制代码
<!-- 条件渲染 -->
<template>
  <MyComponent v-if="condition" />
  <MyComponent v-else />
  
  <!-- 列表渲染 -->
  <MyComponent 
    v-for="item in list" 
    :key="item.id" 
    :data="item" 
  />
</template>
  1. 插槽渲染:
vue 复制代码
<!-- 默认插槽 -->
<MyComponent v-slot="{ data }">
  {{ data }}
</MyComponent>

<!-- 具名插槽 -->
<MyComponent>
  <template #header>Header</template>
  <template #default>Content</template>
</MyComponent>
  1. 动态组件技巧:
vue 复制代码
<script setup>
import { ref, shallowRef } from 'vue'
import ComponentA from './ComponentA.vue'
import ComponentB from './ComponentB.vue'

// 动态切换组件
const current = shallowRef(ComponentA)
</script>

<template>
  <component :is="current" />
  <button @click="current = ComponentB">切换</button>
</template>
  1. 异步组件:
typescript 复制代码
// 基本异步
const AsyncComponent = defineAsyncComponent(() => 
  import('./MyComponent.vue')
)

// 带加载和错误状态
const AsyncComponent = defineAsyncComponent({
  loader: () => import('./MyComponent.vue'),
  loadingComponent: LoadingComponent,
  errorComponent: ErrorComponent,
  delay: 200,
  timeout: 3000
})

这些方法涵盖了Vue 3中组件声明、创建和渲染的主要技术和模式。根据具体场景选择最适合的方式。

关键建议:

  • 推荐使用<script setup>语法
  • 优先使用组合式API
  • 根据实际需求选择合适的组件创建方式
  • 注意性能和代码可读性
相关推荐
angerdream27 分钟前
最新版vue3+TypeScript开发入门到实战教程之路由详解三
前端·javascript·vue.js
数据潜水员3 小时前
三层统计最小力度的四种方法
javascript·vue.js
英俊潇洒美少年4 小时前
Vue3 的 JSX 函数组件,每次更新都会重新运行吗?
前端·javascript·vue.js
Irene19915 小时前
Vue3 响应式系统核心对比:effect, track, trigger,computed, watch, watchEffect
vue.js
saadiya~5 小时前
从插件冗余到极致流畅:我的 Vue 3 开发环境“瘦身”实录
前端·javascript·vue.js
慧一居士6 小时前
Zod 功能、使用场景介绍以及对应场景使用示例
前端·vue.js
Irene19916 小时前
Vue3 举例说明如何编写一个自定义组合式函数(与 Mixins 相比的优势)
vue.js
小马_xiaoen6 小时前
Vue 3 + TS 实战:手写 v-no-emoji 自定义指令,彻底禁止输入框表情符号!
前端·javascript·vue.js
Highcharts.js6 小时前
Highcharts Gantt 实战:从框架集成到高级功能应用-打造现代化、交互式项目进度管理图表
前端·javascript·vue.js·信息可视化·免费
终端鹿7 小时前
setup 语法糖从 0 到 1 实战教程
前端·javascript·vue.js