0

0

vue3组件化开发常用API知识点有哪些

WBOY

WBOY

发布时间:2023-05-16 22:55:26

|

1157人浏览过

|

来源于亿速云

转载

    组件化思想

    为什么使用组件化开发?

    当前前端比较流行的 vue react 等框架,都会通过编写组件来完成业务需求,也就是组件化开发。包括小程序开发也会用到组件化开发的思想。

    分析组件化思想开发应用程序:

    • 将一个完整页面拆分成很多个小组件

    • 每个组件用于完成页面的一个功能模块

    • 每一个组件还可以细分 (父子组件)

      立即学习前端免费学习笔记(深入)”;

    • 通用的组件可以复用到不同的页面

    一个 Vue 的页面,应该像是棵嵌套的组件树的形式来组织:

    vue3组件化开发常用API知识点有哪些

    vue3 入口文件:

    import { createApp } from 'vue';
    import App from './App.vue';
    
    createApp(App).mount('#app');

    createApp()函数传入了一个AppApp 就是一个组件,是项目的根组件。

    下面将分析 Vue3 中组件化开发的常用方法。

    组件通讯

    $props

    • $props 用于向子组件传递数据

    <p> $props: {{$props}} </p>
    • <script setup> 语法糖中需要使用 definePropsApi获取props

    const props = defineProps({
      num: Number,
    })

    $emits

    • $emit 用于调用父级组件的方法

    <button @click="$emit('add')">
      add
    </button>
    • <script setup> 语法糖中需要使用 defineEmitsApi声明emits

    <button @click="add">{{ num }}</button>
    
    const emits = defineEmits(['add'])
    function add() {
      emits('add')
    }

    $parent

    • $parent用于获取父组件实例对象。

    <script setup> 中组件实例不会暴露出来,直接在模板中使用$parent会返回一个空对象。

    为了在 <script setup> 组件中明确要暴露出去的属性,使用 defineExpose 编译器宏:

    const parData = ref("父组件数据");
    defineExpose({
      parData,
    })

    子组件:

    <p>父组件 parData: {{$parent.parData}}</p>

    $attrs

    • 包含了父作用域中不作为组件 props 或自定义事件的 attribute 绑定和事件。

    子组件:

    <Foo a="a" b="b" :num="num" @add="add" />

    在父组件中,$attrs 的值就是 { "a": "a", "b": "b" }

    • 当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定,并且可以通过 v-bind="$attrs" 传入内部组件——这在创建高阶的组件时会非常有用,举个例子:

    父组件:

    <Bar :age=18 sex="boy" />

    子组件 Bar.vue

    <p v-bind="$attrs">将$attrs对象绑定到当前标签</p>

    在浏览器查看DOM,age 和 sex作为属性被绑定到了这个p标签上面。

    • <script setup>中,需要使用useAttrs

    import { useAttrs } from 'vue';
    
    const attrs = useAttrs();
    console.log(attrs.sex); // boy

    proviede & inject

    • 用于跨层级/多层级的组件通信

    • 父组件有一个 provide 选项来提供数据,子组件有一个 inject 选项来开始使用这些数据。

    父级组件:

    Bolt.new
    Bolt.new

    Bolt.new是一个免费的AI全栈开发工具

    下载
    provide("user", "kong");
    provide("pass", 123456);

    子孙级组件:

    const user = inject("user");
    const pass = inject("pass");

    插槽 slot

    用于内容分发,将 <slot> 元素作为承载分发内容的出口。

    SlotComp 组件

    <template>
      <div :>
        <slot name="head"></slot>
      </div>
      <div :>
        <slot name="foot"></slot>
      </div>
    </template>

    使用上面的组件

              <SlotComp>
                <template v-slot:head>
                  <p>head插槽</p>
                </template>
                <template v-slot:foot>
                  <p>foot插槽</p>
                </template>
              </SlotComp>

    SlotComp 组件中带 name属性的 slot插槽内容,会被替换。被替换的内容 需要在父组件中使用 v-slot指令为插槽提供想要显示的内容。

    渲染作用域

                <template v-slot:foot>
                  <p>foot插槽</p>
                  {{msg}}
                  {{items}}
                </template>

    上面的例子,{{items}} 不会显示数据。

    父级模板里的所有内容都是在父级作用域中编译的;子模板里的所有内容都是在子作用域中编译的。

    作用域插槽

    让插槽的内容访问子组件才有的数据:

    <slot name="head" :item="items"></slot>

    插槽内容:

                <template v-slot:head = "slotProps">
                  <p v-for="i in slotProps.item">{{i}}</p>
                </template>

    绑定在 <slot> 元素上的 attribute 被称为插槽 prop。现在,在父级作用域中,我们可以使用带值的 v-slot 来定义我们提供的插槽 prop 的名字,本例中就是slotProps

    v-model

    表单组件

    • v-model 应用在表单上面,实现双向绑定:

    <input v-model="text" />

    自定义组件

    • v-model 应用在自定义组件上面:

    父组件中使用自定义组件:

    const msg = ref('hello world!');
    
    <ModelComp v-model="msg"></ModelComp>

    相当于:

              <ModelComp 
                :modelValue="msg"
                 @update:modelValue="msg = $event"
              >
              </ModelComp>

    自定义组件ModelComp.vue中:

    const props = defineProps({
      modelValue: String
    })
    const emits = defineEmits([
      "update:modelValue"
    ])
    
    const text = ref("请输入..");
    
    // text改变时执行
    watch(text,()=>{
      emits("update:modelValue",text.value);
    })

    改变默认参数

    • 未设置参数时如上,默认绑定的参数是 modelValue update:modelValue

    设置v-model参数:

    <ModelComp v-model:show="show"></ModelComp>

    相当于:

              <ModelComp 
                :show="showFlag"
                 @update:show="showFlag = $event"
              >
              </ModelComp>

    自定义组件ModelComp.vue中:

    const props = defineProps({
      show: Boolean
    })
    const emits = defineEmits([
      "update:show",
    ])

    样式绑定相关

    class

    class绑定:根据需求动态绑定class样式时可以使用一下几种方法

    写法1:对象语法

    <button @click="changeColor" :class="{ active: isActive }">
        点击切换我的文体颜色样式
    </button>
    
    const isActive = ref(false);
    const changeColor = () => {
      isActive.value = !isActive.value;
    }

    写法2:对象语法

    <button @click="changeColor2" :class="classObj">
              点击切换颜色,根据计算属性
    </button>
    
    const isActive2 = reactive({
    active: false,
    })
    const classObj = computed(() => {
    return {
      active: isActive2.active,
      'font-30': true,
    }
    })
    const changeColor2 = () => {
    isActive2.active = !isActive2.active
    }

    写法3:数组语法

    <div :class="[activeClass, errorClass]"></div>

    三目运算符写法

    <div :class="[isActive ? activeClass : '', errorClass]"></div>

    数组语法中结合对象语法使用

    <div :class="[{ active: isActive }, errorClass]"></div>

    style

    动态绑定行内style样式

    三种方式:html代码

          <p :>style绑定</p>
          <p :>style对象绑定(直接绑定到一个对象,代码更清新)</p>
         <p :>style数组绑定</p>

    js 代码

    const colorRed = ref('#f00')
    const styleObj = reactive({
      fontSize: '30px',
    })
    const styleObjRed = reactive({
      color: '#f00',
    })

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    WorkBuddy
    WorkBuddy

    腾讯云推出的AI原生桌面智能体工作台

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    java基础知识汇总
    java基础知识汇总

    java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

    1566

    2023.10.24

    Go语言中的运算符有哪些
    Go语言中的运算符有哪些

    Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    241

    2024.02.23

    php三元运算符用法
    php三元运算符用法

    本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

    150

    2025.10.17

    class在c语言中的意思
    class在c语言中的意思

    在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

    870

    2024.01.03

    python中class的含义
    python中class的含义

    本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

    30

    2025.12.06

    js正则表达式
    js正则表达式

    php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

    530

    2023.06.20

    js获取当前时间
    js获取当前时间

    JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

    576

    2023.07.28

    js 字符串转数组
    js 字符串转数组

    js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    760

    2023.08.03

    C# ASP.NET Core微服务架构与API网关实践
    C# ASP.NET Core微服务架构与API网关实践

    本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

    76

    2026.03.11

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Go语言实战之 GraphQL
    Go语言实战之 GraphQL

    共10课时 | 0.9万人学习

    微信小程序开发之API篇
    微信小程序开发之API篇

    共15课时 | 1.3万人学习

    Laravel---API接口
    Laravel---API接口

    共7课时 | 0.7万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号