当前位置: 首页 > news >正文

Vue 全组件 局部组件

一、组件定义和使用

1、全局组件

定义

<template>

    <div>

        <h1>This is a global component</h1>

    </div>

</template>

<script lang="ts">

</script>

<style></style>

 

导入

全局组件在main.ts(Vue + TS的项目)引入,

或者在main.js(Vue + JS的项目)引入

import { createApp } from 'vue'

import App from './App.vue'

import router from './router'

import store from './store'

import GlobalComponent  from "../src/components/component/GlobalComponent.vue";

const app = createApp(App)

app.component("GlobalComponent",GlobalComponent);

app.use(store).use(router).mount('#app')

 

使用 

全局组件可以在任意组件中使用,不需要再次导入

2、局部组件

定义

导入与使用

二、组件通信

1、props

(1)传递单个值

 

(2)传递多个值

如果传递的时对象,对象在被子组件的props接收时需要解构,依次写在props数组中

 

 传递的如果是一个个的值,则直接在props数组中写入即可

 

2、插槽

插槽的作用:让子组件可以接收父组件传过来的元素、组件

(1)匿名插槽

如果父元素只传递一个元素,或者传递的多个元素会在一个地方使用,那么可以使用匿名插槽

 

 

(2)具名插槽

父组件会传递多个元素,这些元素需要再不同的地方使用,这时需要使用具名插槽进行区分

 

 

 

(3)作用域插槽

父组件需要用到子组件中的数据时,可以使用作用域插槽将子组件的数据传递过去

子组件

<template>

    <div>

        <h1>This is a local component</h1>

       <slot v-for="(item,index) in list" :item="item" :index="index"/>

    </div>

</template>

<script lang="ts" setup>

const list = [1,2,3,4];

</script>

 //父组件

<template>

  <div>

    <h1>This is a component view</h1>

    <div>

      <GlobalComponent />

      <LocalComponent v-slot="slotProps">

        <div>{{ slotProps.item }}*****{{ slotProps.index }}</div>

      </LocalComponent>

    </div>

  </div>

</template>

//父组件写法二

<template>

  <div>

    <h1>This is a component view</h1>

    <div>

      <GlobalComponent />

      <LocalComponent v-slot="{item,index}">

        <div>{{ item }}*****{{ index }}</div>

      </LocalComponent>

    </div>

  </div>

</template> 

3、provide&inject

父组件给子组件传值,子组件使用props接收,如果孙子组件乃至重孙子组件要使用父组件的数据,那么就要一层层用props传递,特别麻烦。

父组件使用provide(提供)提供数据

子组件、孙子组件、重孙子组件....可以使用inject接收数据

//父组件

<template>

  <div>

    <LocalComponent />

  </div>

</template>

<script setup lang="ts">

import LocalComponent from "../components/component/LocalComponent.vue";

import { provide, ref } from "vue";

const msg = ref('hello world');

provide('msg',msg);

</script>

 //子组件

<template>

    <div>

        LocalComponent

        <GrandChild />

    </div>

</template>

<script lang="ts" setup>

import GrandChild from '../component/GrandChild.vue';

</script>

 //孙子组件

<template>

    <div>

        <h1>This is a GrandChild component</h1>

        {{ msg }}

    </div>

</template>

<script lang="ts" setup>

import { inject } from "vue";

const msg = inject('msg');

</script>

<style></style>

4、事件通信

 

三、异步组件

http://www.lryc.cn/news/299864.html

相关文章:

  • 几个经典金融理论
  • c++语言max函数的使用
  • c++阶梯之类与对象(下)
  • 机器学习--K-近邻算法常见的几种距离算法详解
  • <网络安全>《30 网络信息安全基础(1)常用术语整理》
  • Git远程仓库的使用(Gitee)及相关指令
  • vscode +markdown 的安装和使用
  • Python爬虫之自动化测试Selenium#7
  • 快速学习Spring
  • c语言操作符(上)
  • vue3 可视化大屏自适应屏幕组件
  • SpringCloud入门概述
  • 刷题计划_冲绿名
  • 【微信小程序开发】小程序版的防抖节流应该怎么写
  • 单片机学习笔记---蜂鸣器播放提示音音乐(天空之城)
  • 软件实例分享,茶楼收银软件管理系统,支持计时计费商品销售会员管理定时语音提醒功能
  • clang前端
  • ARM:AI 的翅膀,还能飞多久?
  • 【C语言】常见字符串函数的功能与模拟实现
  • pyGMT初步使用
  • 神经网络 | CNN 与 RNN——深度学习主力军
  • thinkphp6入门(20)-- 如何上传图片、文件
  • 【Linux技术宝典】深入理解Linux基本指令:命令行新手指南
  • C++:Level1阶段测试
  • autojs自动化刷视频脚本
  • 鲁南制药“健康幸福中国年”主题航班,开启探寻健康与幸福的旅程
  • CISA知识点
  • C语言求解猴子分桃子
  • 本地部署 Stable Cascade
  • LeetCode 二叉树/n叉树的解题思路