当前位置:首页 > 技术 > 正文内容

Vue组件开发与通信详解

访客 技术 2026年6月18日 1

深入理解Vue组件

Vue.js的组件化开发是现代前端开发的重要组成部分,它使得代码更加模块化、易于维护和复用。本文将详细探讨Vue组件的基础知识及其高级应用。

组件基础

什么是组件?

<!-- 组件就像自定义HTML元素 -->
<user-profile 
  :userinfo="currentUser" 
  :editable="true"
  @save="handleSave"
/>

// 内部包含:
// 1. 模板 (HTML结构)
// 2. 脚本 (JavaScript行为)
// 3. 样式 (CSS样式)
特性HTML元素Vue组件
可复用性
封装性
数据绑定不支持支持
事件处理基础丰富
生命周期完整
样式隔离支持

组件注册

// main.js
import { createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局注册组件
app.component('MyButton', {
  template: '<button @click="onClick">点击我</button>',
  methods: {
    onClick() {
      this.$emit('click')
    }
  }
})

// 局部注册组件
<template>
  <div>
    <LocalCounter />
    <SpecialButton />
  </div>
</template>

<script>
import LocalCounter from './LocalCounter.vue'
import SpecialButton from './SpecialButton.vue'

export default {
  components: {
    LocalCounter,
    CustomButton: SpecialButton
  }
}
</script>

单文件组件(SFC)

<template>
  <div class="user-card">
    <img :src="avatar" :alt="name" class="avatar" />
    <div class="user-info">
      <h3>{{ name }}</h3>
      <p>{{ email }}</p>
    </div>
    <button @click="follow" class="follow-btn">
      {{ isFollowing ? '取消关注' : '关注' }}
    </button>
  </div>
</template>

<script>
export default {
  props: ['userId', 'name', 'email', 'avatar', 'initialFollowing'],
  data() {
    return {
      isFollowing: this.initialFollowing
    }
  },
  methods: {
    follow() {
      if (this.isFollowing) {
        // 取消关注逻辑
      } else {
        // 关注逻辑
      }
    }
  }
}
</script>

<style scoped>
.user-card {
  padding: 16px;
  background: white;
  transition: box-shadow 0.3s ease;
}
</style>

组件通信

父传子:Props

<!-- ParentComponent.vue -->
<template>
  <ChildComponent title="用户列表" :items="userList" />
</template>

<script>
export default {
  data() {
    return {
      userList: ['Alice', 'Bob']
    }
  }
}
</script>

<!-- ChildComponent.vue -->
<template>
  <ul>
    <li v-for="item in items" :key="item">{{ item }}</li>
  </ul>
</template>

<script>
export default {
  props: ['title', 'items']
}
</script>

子传父:$emit

<!-- ChildComponent.vue -->
<template>
  <button @click="increment">增加</button>
</template>

<script>
export default {
  emits: ['increment'],
  methods: {
    increment() {
      this.$emit('increment')
    }
  }
}
</script>

<!-- ParentComponent.vue -->
<template>
  <ChildComponent @increment="count++" />
</template>

<script>
export default {
  data() {
    return {
      count: 0
    }
  }
}
</script>

插槽 Slot

默认插槽

<!-- BaseLayout.vue -->
<template>
  <header>
    <slot>默认标题</slot>
  </header>
  <main>
    <slot>默认内容</slot>
  </main>
</template>

<!-- 使用组件 -->
<template>
  <BaseLayout>
    <template #default>
      <h2>主要内容</h2>
    </template>
  </BaseLayout>
</template>

具名插槽

<!-- CardComponent.vue -->
<template>
  <header>
    <slot name="header">默认标题</slot>
  </header>
  <footer>
    <slot name="footer"><button>默认按钮</button></slot>
  </footer>
</template>

<!-- 使用组件 -->
<template>
  <CardComponent>
    <template #header><h3>用户信息</h3></template>
    <template #footer><button>编辑</button></template>
  </CardComponent>
</template>

动态组件和异步组件

动态组件

<template>
  <component :is="currentTab"></component>
</template>

<script>
import HomePage from './HomePage.vue'
import AboutPage from './AboutPage.vue'

export default {
  data() {
    return {
      currentTab: 'HomePage'
    }
  },
  components: {
    HomePage,
    AboutPage
  }
}
</script>

异步组件加载

import { defineAsyncComponent } from 'vue'

const AsyncComponent = defineAsyncComponent(() => import('./HeavyComponent.vue'))

export default {
  components: {
    AsyncComponent
  }
}
标签: Vue组件化

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。