我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

当前前端比较流行的 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" 传入内部组件&mdash;&mdash;这在创建高阶的组件时会非常有用,举个例子:

父组件:

<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 选项来开始使用这些数据。

父级组件:

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',
})

以上就是vue3组件化开发常用API知识点有哪些的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

组件化思想为什么使用组件化开发?当前前端比较流行的VueReact等框架,都会通过编写组件来完成业务需求,也就是组件化开发。包括小程序开发也会用到组件化开发的思想。分析组件化思想开发应用程序:将一个完整页面拆分成很多个小组件每个组件用于完成页面的一个功能模块每一个组件还可以细分(父子组件)通用的组件可以复用到不同的页面一个Vue的页面,应该像是棵嵌套的组件树的形式来组织:vue3入口文件:import{createApp}from&#39;vue&#39;;importAppfr
2023-05-17

Vue3.x项目开发的常用知识点有哪些

这篇文章主要介绍“Vue3.x项目开发的常用知识点有哪些”,在日常操作中,相信很多人在Vue3.x项目开发的常用知识点有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3.x项目开发的常用知识点有哪些
2023-06-30

Python开发常用的知识点有哪些

这篇文章主要介绍“Python开发常用的知识点有哪些”,在日常操作中,相信很多人在Python开发常用的知识点有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python开发常用的知识点有哪些”的疑惑有所
2023-06-27

ASP.NET控件开发基础知识点有哪些

这篇文章主要介绍ASP.NET控件开发基础知识点有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!ASP.NET控件开发基础的总结1.1何处继承自定义控件一般从以下几个基类(此处不包含数据控件)一.Control类
2023-06-18

web自动化平台开发的知识点有哪些

本篇内容主要讲解“web自动化平台开发的知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web自动化平台开发的知识点有哪些”吧!模型设计中的枚举值在前期的准备过程中,最开始写页面的时候
2023-06-04

提高开发效率的Vue3常用插件有哪些

这篇文章主要介绍“提高开发效率的Vue3常用插件有哪些”,在日常操作中,相信很多人在提高开发效率的Vue3常用插件有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”提高开发效率的Vue3常用插件有哪些”的疑
2023-07-04

编程热搜

目录