Vue基础2:传值方法

news2024/9/24 1:16:19

Description

传值就是为了联动,能够及时准确传值获取值才是王道。

Valuation Methods 

props和$emit

props是父传子,$emit是子传父。

props的使用

父组件传出值

<tableList ref="table" :options="options" :header-data="Columns" :table-data="Data" />

 父组件的中的子组件标签上我们加入的options,headerData,tableData三个变量是准备要传给子组件的。

子组件收到值

props: {
    tableData: {
      type: Array,
      default: () => {
        return []
      }
    },

    headerData: {
      type: Array,
      default: () => {
        return []
      }
    },

    options: {
      type: Object,
      default: () => {
        return {
          multiSelect: true, // boolean 是否多选
          singleSelect: false, // boolean 是否单个checkbox
          isindex: false, // boolean 是否展示序列号
          stripe: true, // boolean 斑马纹
          border: true, // boolean 纵向边框
          size: 'medium', // String  medium / small / mini  table尺寸
          fit: true, // 自动撑开
          pagination: true, // 是否有分页
          numPage: false
        }
      }
    },

}

 延申

属性/方法作用
type传值的类型
default默认值;如果没有传,就使用
requied值为true/false,代表是否父组件是否必须传
validator(val){}可以判断父组件传过来的值是否有效

props:{
    name:{

        type:String,
        default:'默认为王三',
        required:true,
        validator(val){
            
            return val>0&&val<10
        }

    }

}

 $emit的使用

子组件传出值

that.$emit('usbKeyForm', that.usbKeyForm)

父组件收到值

<certificateDialog :ssuingName="ssuingName" @usbKeyForm="usbKeyForm"/>


methods: {
    usbKeyForm(val) {
      this.SerialNumber = val.SerialNumber
    },
}

思考:为什么两种方法不一样呢?

首先要明白传值的前提,为什么要传值,因为作用域。其实在Vue.js中每个组件都有自己的作用域,而且每个组件定义了一个props属性可以去接收父组件传过来的值,而且定义了type类型就是为了确定父级传过来的值的类型就是我们需要的,当然也可以修饰数据。如果加入required属性,值为true的时候,要求父组件必须要传的。default是设置默认值的,如果父组件没有传我们就使用默认值。所以我们经常看到使用props时候经常使用type+default两个属性搭配使用。

$emits传值原理是通过事件系统进行传值的,因为作用域是上下关系,你要是像下上关系,就得需要闭包传值。

$attrs和$listeners

组件关系A组件---》B组件----》C组件;大家都知道props和$emit是最常用的传值方法,但是仅限A到B或者B到A,如果A到C或者C到A呢?就需要用到$attrs和$listeners了

$attrs的使用

$attrs可以继承父组件里边的属性数据,并且携带下去。

通俗地来说就是如果从父组件传过来的值,没有在子组件中被接收,那么这些值就会被存在$attrs对象中。

 爷组件传出值

<son title="aaaaaaaaaaa" name="李四"/>

子组件收到值(子组件作为中间组件继续传递  v-bind="$attrs"

<template>
  <div>
      儿子组件:{{$attrs.name}}
      <div>
         <sunzi v-bind="$attrs"/>
      </div>
  </div>
</template>
 
<script>
import sunzi from './sunzi.vue';
export default {
  inheritAttrs: true,
  components:{sunzi},
  mounted(){
      console.log(this.$attrs)  //{title:"aaaaaaaaaaa" name:"李四"}
  }
}

孙子组件收到值(孙子组件使用 inheritAttrs: false)

<template>
  <div>孙:{{name}}{{title}}</div>
</template>
 
<script>
export default {
 inheritAttrs: false,
  props: [
    "name",
    "title", //注意props里的参数名称不能改变,必须和父组件传递过来的是一样的
  ],
  data() {
    return {};
  },
  mounted(){
      console.log(this.$attrs) //可直接使用数据或者调用根组件的方法
  }
};
 
 
 

或者

 
<template>
  <div>
      或者:{{$attrs.name}},{{$attrs.title}}
  </div>
</template>
 
<script>
export default {
 inheritAttrs: false,
  data() {
    return {};
  },
  mounted(){
      console.log(this.$attrs)//可直接使用数据或者调用根组件的方法
  }
};
</script>

inheritAttrs: false 的含义是不希望本组件的根元素继承父组件的attribute,同时父组件传过来的属性(没有被子组件的props接收的属性),也不会显示在子组件的dom元素上,但是在组件里可以通过其$attrs可以获取到没有使用的注册属性。

inheritAttrs: false 是不会影响 style 和 class 的绑定

inheritAttrs: true

 inheritAttrs: false  不想继承所有父组件的内容,同时也不在组件根元素dom上显示属性

$listeners的使用

子组件传出值

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/958610.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GE MRP680489 IS200VTCCH1CBB印刷电路板

信号处理&#xff1a; 这个印刷电路板通常用于信号处理和数据传输&#xff0c;可以与其他设备或模块进行通信&#xff0c;如传感器、执行器或控制器。 通信接口&#xff1a; IS200VTCCH1CBB 可能具有多种通信接口&#xff0c;用于与其他设备和系统进行数据交换&#xff0c;包括…

通过「内网穿透」技术,实现出差期间远程访问企业局域网中的象过河ERP系统

文章目录 概述1.查看象过河服务端端口2.内网穿透3. 异地公网连接4. 固定公网地址4.1 保留一个固定TCP地址4.2 配置固定TCP地址 5. 使用固定地址连接 概述 ERP系统对于企业来说重要性不言而喻&#xff0c;不管是财务、生产、销售还是采购&#xff0c;都需要用到ERP系统来协助。…

8月31日-9月 第六章 案例:MySQL主从复制与读写分离(面试重点,必记)

本章结构 案例概述 案例前置知识点 详细图示 1、什么是读写分离&#xff1f; 读写分离&#xff0c;基本的原理是让主数据库处理事务性增、改、删操作&#xff08;INSERT、UPDATE、DELETE&#xff09;&#xff0c;而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导…

基于Python的IOS自动化测试环境搭建

文章目录 一、测试架构介绍1.1 WebDriverAgent原理分析1.2 tidevice原理分析二、环境安装2.1 iOS 设备安装 WebDriverAgent2.2 安装iTunes2.3 安装tidevice2.4 安装facebook-wda自动化三、操作流程一、测试架构介绍 以下为测试架构原理图 手机端的WDA Runner(WebDriverAgent…

如何通过网络远程访问电脑?

怎么远程访问公司电脑&#xff1f; “你好&#xff0c;我想通过网络从外面远程访问公司的电脑&#xff0c;这可能吗&#xff1f;您知道如何通过网络远程访问另一台电脑吗&#xff1f;” 借助远程访问工具&#xff0c;我们是可以通过网络远程访问公司电脑的。通过…

静电离子风棒的联网智能实时监控的操作步骤

静电离子风棒的联网智能实时监控可以通过以下步骤进行&#xff1a; 1. 获取数据&#xff1a;将静电离子风棒上的传感器与网络连接&#xff0c;以获取实时数据。传感器可能包括温度传感器、湿度传感器、电流传感器等&#xff0c;用于监测离子风棒的工作状态和环境信息。 2. 数…

Elasticsearch:自动使用服务器时间设置日期字段并更新时区

在大多数情况下&#xff0c;你的数据包含一个以 create_date 命名的字段。 即使没有日期字段&#xff0c;处理各种格式和时区的日期对数据仓库来说也是一个重大挑战。 与此类似&#xff0c;如果要检测变化的数据&#xff0c;则必须准确设置日期字段。 在 Elasticsearch 中还有…

蓝牙运动耳机哪个牌子好、好用的运动蓝牙耳机推荐

作为一个热爱运动的人&#xff0c;我对耳机非常关注。我相信许多喜欢运动的人在锻炼时都会佩戴耳机&#xff0c;这样可以为运动增添一份乐趣&#xff0c;享受自己喜爱的音乐或聆听有趣的小说&#xff0c;激发内心的动力。但很多人都不知道要怎么选一款优质的运动耳机&#xff0…

C语言:字符函数和字符串函数(一篇拿捏字符串函数!)

目录 求字符串长度&#xff1a; 1. strlen(字符串长度) 长度不受限制函数&#xff1a; 2. strcpy(字符串拷贝) 3. strcat(字符串追加) 4. strcmp(字符串比较) 长度受限制函数&#xff1a; 5. strncpy(字符串拷贝) 6. strncat(字符串追加) 7. strncmp(字符串比较) 字…

关于大学考研与不考研自己一点看法

据网上报道&#xff0c;2023年研究生报考人数为474万&#xff0c;相较22年报名人数457万人,同比增长 17 万 2023年的考研录取率为20&#xff05;,如今,在北京的硕士博士生超过本科生人数 学历的贬值&#xff0c;通胀,速度远远超乎了想象 近几年的考研热,考公,考编热是年年基本上…

完美解决xinput1_3.dll丢失问题,修复xinput1_3.dll文件

在电脑游戏中经常遇到xinput1_3.dll丢失的问题&#xff0c;这个问题是因为系统缺少该文件而引起的。而且&#xff0c;这个问题很容易导致游戏无法正常运行&#xff0c;给玩家带来很大的烦恼。在本文中&#xff0c;我们将详细介绍如何修复这个问题&#xff0c;给大家详细的说明多…

YOLO目标检测——时间检测数据集下载分享

时间数据集是表示一天中不同时间的图像集合&#xff0c;日出和日落被视为同一类别。数据集包含日出/日落、白天场景和夜间场景的图像&#xff0c;并已重新缩放为 224 x 224 x 3 像素&#xff0c;描绘了不同的地点和不同的天气条件&#xff0c;如晴朗的天空&#xff0c;阴天等。…

Chrome自动升级了,找不到最新版本的webdriver怎么办?

Chrome自动升级了,找不到最新版本的webdriver怎么办? 背景解决办法 背景 我用Selenium开发了Facebook和Linkedin爬虫&#xff0c;有些新需求要调一下&#xff0c;今天启动selenium时有报错&#xff0c;报错如下&#xff1a;selenium.common.exceptions.SessionNotCreatedExce…

pygame实现物体运动拖尾尾迹-渐隐版

解说文案&#xff1a; 视频讲解&#xff1a;https://www.bilibili.com/video/BV14w411S74E/ 上一集我们实现了物体本体形式的拖尾&#xff0c;这一集我们基于上一集来实现物体逐渐变透明到消失的拖尾。 上集我们也说过&#xff0c;逐渐变透明到消失的物体拖尾只不过是给物体…

Qt无边框青绿色主题

收费产品&#xff0c;学生党、闹眼子党勿扰 收费金额&#xff1a;500元 1 概述 最近因项目需要&#xff0c;写了一个炫酷的青绿色、无边框界面&#xff0c;和3DSMax的界面有点类似。 2 截图 首先看看3DSMax的界面 不知道大家看出来没&#xff0c;这个ui其实很简单&#xff…

15. Docker实战监控神器Uptime Kuma

目录 1、前言 2、什么是Uptime Kuma? 3、Docker部署Uptime Kuma 3.1、安装 3.2、访问 3.3、配置 3.4、集成飞书机器人 3.5、效果 1、前言 在利用Docker部署项目时&#xff0c;我们需要时刻知道已部署的容器的状态。且通常会把所有的站点监控配置到云平台上&#xff0c…

算法通关村十三关 | 辗转相除法、素数和丑数

1. 辗转相除法 辗转相除法又称欧几里得算法&#xff0c;求两个数的最大公因数&#xff0c;希腊数学家喜欢用图形来处理问题&#xff0c;于是将要求最大公约数问题转化为&#xff0c;以两个数字构成矩形&#xff0c;寻找可以铺满整个矩形的最大正方形的边长问题。 题目 例如8和1…

基于Spring Boot的企业门户网站设计与实现(Java+spring boot+MySQL)

获取源码或者论文请私信博主 演示视频&#xff1a; 基于Spring Boot的企业门户网站设计与实现&#xff08;Javaspring bootMySQL&#xff09; 使用技术&#xff1a; 前端&#xff1a;html css javascript jQuery ajax thymeleaf 微信小程序 后端&#xff1a;Java springboot…

<Xilinx AXI4> AXI4_Full(一)总线说明

目录 01 AXI4-Full Brust传输介绍 write burst transcation read burst transcation 02 AXI4_Full读写事务接口说明 写事务(Write transaction) AXI4-Full_master写事务逻辑信号 AXI4-Full_slave写事务逻辑信号 读事务(Read transaction) AXI4-Full_master读事务逻辑信…

删除、移动、复制文件时总是要卡在99%一段时间解决方法

Win10文件夹重命名、移动、删除等操作卡顿3-5秒。 原因分析: 查看发现&#xff0c;卡顿期间资源管理器无响应&#xff0c;并且其高度占用CPU资源&#xff0c;但是对于非文件夹文件操作没有问题。 解决方案: 1、双击“此电脑”&#xff0c;选择“查看”&#xff0c;再选择“选…