VUE3 常用的组件介绍

Vue 组件简介

Vue 组件是构建 Vue 应用程序的核心部分,组件帮助我们将 UI 分解为独立的、可复用的块,每个组件都有自己的状态和行为。Vue 组件通常由模板、脚本和样式组成。组件的脚本部分包含了各种配置选项,用于定义组件的逻辑和功能。

组件的常见选项及其描述
  1. data

    • 描述data 选项用于定义组件的响应式数据。它是一个函数,返回一个对象,这个对象包含了该组件的初始状态。

    • 示例

      javascript 复制代码
      data() {
        return {
          message: 'Hello, Vue!'
        };
      }
  2. methods

    • 描述methods 选项用于定义组件的方法,方法可以在模板中通过事件绑定进行调用。它们通常用于处理用户输入、事件响应或其他操作。

    • 示例

      javascript 复制代码
      methods: {
        greet() {
          console.log(this.message);
        }
      }
  3. computed

    • 描述computed 选项用于定义计算属性,它是基于响应式数据进行计算的,并且只有在依赖的响应式数据发生变化时才会重新计算。它们常用于根据已有数据衍生出新的数据。

    • 示例

      javascript 复制代码
      computed: {
        reversedMessage() {
          return this.message.split('').reverse().join('');
        }
      }
  4. watch

    • 描述watch 选项用于监听响应式数据的变化,可以在数据变化时执行某些操作,比如异步操作或调试。watch 是响应式数据的"观察者"。

    • 示例

      javascript 复制代码
      watch: {
        message(newValue, oldValue) {
          console.log(`Message changed from ${oldValue} to ${newValue}`);
        }
      }
  5. props

    • 描述props 选项用于从父组件传递数据到子组件。它定义了父组件传递给子组件的属性,可以用于传递基本数据类型或对象。

    • 示例

      javascript 复制代码
      props: {
        title: String
      }
  6. created

    • 描述created 是生命周期钩子之一,组件实例在创建后立即被调用,此时数据已初始化,但 DOM 尚未挂载。

    • 示例

      javascript 复制代码
      created() {
        console.log('Component created');
      }
  7. mounted

    • 描述mounted 是生命周期钩子之一,组件实例被挂载到 DOM 后立即被调用。在这个阶段,可以访问到 DOM 元素。

    • 示例

      javascript 复制代码
      mounted() {
        console.log('Component mounted');
      }
  8. beforeDestroy

    • 描述beforeDestroy 是生命周期钩子之一,在组件实例销毁之前调用。此时,组件仍然处于 DOM 中。

    • 示例

      javascript 复制代码
      beforeDestroy() {
        console.log('Component about to be destroyed');
      }
  9. destroyed

    • 描述destroyed 是生命周期钩子之一,在组件实例销毁后立即调用。此时,组件从 DOM 中移除。

    • 示例

      javascript 复制代码
      destroyed() {
        console.log('Component destroyed');
      }
  10. emits

    • 描述emits 用于声明组件会触发的自定义事件。通过这个选项可以限制和验证组件能够触发的事件。

    • 示例

      javascript 复制代码
      emits: ['update', 'submit']
  11. inheritAttrs

    • 描述inheritAttrs 选项控制是否自动将父组件传递的属性绑定到子组件的根元素上。设置为 false 时,可以自定义如何传递属性。

    • 示例

      javascript 复制代码
      inheritAttrs: false
  12. name

    • 描述name 用于给组件指定一个名称,通常用于调试或递归组件时。

    • 示例

      javascript 复制代码
      name: 'MyComponent'
  13. directives

    • 描述directives 选项用于定义自定义指令。Vue 允许通过 directives 选项注册全局或局部指令。

    • 示例

      javascript 复制代码
      directives: {
        focus: {
          inserted(el) {
            el.focus();
          }
        }
      }
  14. provideinject

    • 描述provideinject 用于父子组件之间的跨级数据传递。provide 在父组件中定义,inject 在子组件中使用。它们允许跨越多级组件传递数据而不必一层层通过 props

    • 示例

      javascript 复制代码
      provide() {
        return {
          message: 'Hello from parent'
        };
      }
      
      inject: ['message']

总结

这些选项构成了 Vue 组件的核心,它们让我们能够定义组件的状态、行为和生命周期。每个选项都有其独特的用途,可以帮助我们根据需要定制组件的功能。

如果你有其他问题或需要进一步的解释,随时告诉我!

相关推荐
灵感__idea4 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea5 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd7 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌7 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈7 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫8 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝8 小时前
svg图片
前端·css·学习·html·css3
橘子编程8 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇8 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧8 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint