Vue3+TypeScript学习笔记(九)

简介: 本节记录Vue组件局部注册、全局注册和递归组件相关知识
  1. Vue中的组件注册方式分为局部注册和全局注册两种,在Vue3setup语法糖中组件不用额外defineComponent,直接引入就可以使用。通过这种方式注册的组件为局部注册。
  2. 全局注册:全局注册需要先将组件引入main.ts中,然后用app.component()函数进行全局注册,该函数接收两个参数,第一个是组件的名称,第二个是组件实例对象

Main.ts

import { createApp } from 'vue'
// import './style.css'
import App from './App.vue'
// Card是一个预先定义好的组件
import Card from './components/Card.vue';

export const app = createApp(App)

// 注册成全局组件(第一个是名字,第二个是组件实例)
app.component('Card',Card)

app.mount('#app')

Card.vue

<template>
  <div class="card">
    <header>
      <div>标题</div>
      <div>副标题</div>
    </header>
    <section>
      <div>内容</div>
    </section>
  </div>
</template>

<script setup lang="ts">
  import { ref, reactive, onMounted } from 'vue'
</script>

<style scoped lang="less">
  @border: #ccc;
  .card {
    border: 1px solid @border;
  width: 400px;
  header{
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid @border;
  padding: 5px;
  }
  section{
    padding: 5px;
    min-height: 300px;
  }
  }
</style>
  1. 递归组件:由组件调用自身形成,通常在组件中还嵌套着和自身结构相同(必须完全一致)的组件时使用

App.vue(用于Mock数据给子组件)

<template>
    <Tree :data="data"></Tree>
</template>

<script setup lang="ts">
import { ref, reactive } from 'vue'
import Tree from './components/Tree.vue'
interface Tree {
    name: string
    checked: boolean
  // children可有可无
    children?: Tree[]
}
const data = reactive<Tree[]>([
    {
        name: '1-1',
        checked: false,
    },
    {
        name: '2-1',
        checked: false,
        children: [
            {
                name: '2-2',
                checked: false,
                children:[
                    {
                        name:'2-3',
                        checked:false,
                    }
                ]
            },
        ],
    },
    {
        name:'3-1',
        checked:true,
    }
])

</script>

<style scoped></style>

Tree.vue

<template>
    <div @click.stop="clickTap(item,$event)" class="tree" v-for="item in data">
        <input v-model="item.checked" type="checkbox" />
        <span>{{ item.name }}</span>
        <!-- 将data再次传入,由于空数组的逻辑结果依然为true,因此直接使用length判断,当length为0时结束渲染 -->
        <Tree v-if="item.children?.length" :data="item?.children"></Tree>
    </div>
</template>

<script setup lang="ts">
import { ref, reactive } from 'vue'
interface Tree {
    name: string
    checked: boolean
    children?: Tree[]
}
defineProps<{
    data: Tree[]
}>()
const clickTap = (item:Tree,e: MouseEvent) => {
    console.log(item,e.target)
}
</script>

<style scoped>
.tree {
    margin-left: 20px;
}
</style>
相关文章
|
5月前
|
JavaScript 前端开发 IDE
[译] 用 Typescript + Composition API 重构 Vue 3 组件
[译] 用 Typescript + Composition API 重构 Vue 3 组件
[译] 用 Typescript + Composition API 重构 Vue 3 组件
|
3月前
|
JavaScript 安全 开发工具
在 Vue 3 中使用 TypeScript
【10月更文挑战第3天】
|
5月前
|
JavaScript API
如何使用Vue 3和Type Script进行组件化设计
【8月更文挑战第16天】如何使用Vue 3和Type Script进行组件化设计
52 3
|
5月前
|
JavaScript API
如何使用Vue 3和Type Script进行组件化设计
【8月更文挑战第16天】如何使用Vue 3和Type Script进行组件化设计
97 1
|
5月前
|
资源调度 JavaScript 前端开发
Vue3+TypeScript前端项目新纪元:揭秘高效事件总线Mitt,轻松驾驭组件间通信的艺术!
【8月更文挑战第3天】Vue3结合TypeScript强化了类型安全与组件化开发。面对大型应用中复杂的组件通信挑战,可通过引入轻量级事件发射器Mitt实现事件总线模式。Mitt易于集成,通过简单几步即可完成安装与配置:安装Mitt、创建事件总线实例、并在组件中使用`emit`与`on`方法发送及监听事件。此外,利用TypeScript的强大类型系统确保事件处理器正确无误。这种方式有助于保持代码整洁、解耦组件,同时提高应用的可维护性和扩展性。不过,在大规模项目中需谨慎使用,以防事件流过于复杂难以管理。
135 1
|
5月前
|
JavaScript 前端开发 安全
立等可取的 Vue + Typescript 函数式组件实战
立等可取的 Vue + Typescript 函数式组件实战
|
5月前
|
开发框架 前端开发 JavaScript
在基于vue-next-admin的Vue3+TypeScript前端项目中,为了使用方便全局挂载对象接口
在基于vue-next-admin的Vue3+TypeScript前端项目中,为了使用方便全局挂载对象接口
|
5月前
|
开发框架 前端开发 JavaScript
在Vue3+TypeScript 前端项目中使用事件总线Mitt
在Vue3+TypeScript 前端项目中使用事件总线Mitt
|
5月前
|
JavaScript 前端开发 安全
解锁Vue3与TypeScript的完美搭档:getCurrentInstance带你高效打造未来前端
【8月更文挑战第21天】Vue3的getCurrentInstance方法作为Composition API的一部分,让开发者能在组件内访问实例。结合TypeScript,可通过定义组件实例类型实现更好的代码提示与类型检查,提升开发效率与代码质量。例如,定义一个带有特定属性(如myData)的组件实例类型,可以在setup中获取并安全地修改这些属性。这种方式确保了一致性和减少了运行时错误,使开发更加高效和安全。
211 0
|
5月前
|
JavaScript 测试技术 API
Vue 3 与 TypeScript:最佳实践详解
Vue 3 与 TypeScript:最佳实践详解