1. 概述

韦奇定律告诉我们:大部分人都很容易被别人的话所左右,从而开始动摇、怀疑,最终迷失自我。因此我们要努力的坚定信念,相信自己,才不会被周围的环境所左右,才能取得最终的胜利。

言归正传,之前我们聊了组件的概念,既然有多个组件,那自然存在组件间传参的问题,今天我们就来聊聊 VUE 的 组件传参。

2. 组件传参

2.1 初识组件传参

<body>
<div id="myDiv"></div>
</body>
<script>
const app = Vue.createApp({
template:`
<div>
<test content="hello" />
</div>
`
});
app.component("test", {
props:['content'],
template:`
<div>{{content}}</div>
`
});
      const vm = app.mount("#myDiv");

从例子中可以看出,我们在主组件的 test 组件中增加了属性 content,并在 test 组件中使用 props 接收了 content 属性,然后在 template 中使用

2.2 组件参数绑定数据

    const app = Vue.createApp({
data() {
return {
num: 123
}
},
template:`
<div>
<test :content="num" />
</div>
`
}); app.component("test", {
props:['content'],
template:`
<div>{{content}}</div>
`
});

这个例子中,我们稍微改进了一下,组件的属性不再是写死的,而是使用我们之前学的绑定知识,使用 :content="num",与数据中的 num 绑定

2.3 向组件中传多个参数

    const app = Vue.createApp({
data() {
return {
num1: 123,
num2: 456,
num3: 789
}
},
template:`
<div>
<test :num1="num1" :num2="num2" :num3="num3" />
</div>
`
}); app.component("test", {
props:['num1', 'num2', 'num3'],
template:`
<div>{{num1}}</div>
<div>{{num2}}</div>
<div>{{num3}}</div>
`
});

同理,在组件 test 的标签中多写一些属性,num1、num2、num3,然后在 test 组件中使用 props 接收这些参数

似乎没有什么问题,但如果需要传的参数很多, 就有点不优雅了

2.4 向组件中传多个参数-改进版1

    const app = Vue.createApp({
data() {
return {
params : {
num1: 123,
num2: 456,
num3: 789
}
}
},
template:`
<div>
<test v-bind="params" />
</div>
`
}); app.component("test", {
props:['num1', 'num2', 'num3'],
template:`
<div>{{num1}}</div>
<div>{{num2}}</div>
<div>{{num3}}</div>
`
});

这个例子,把 num1、num2、num3 封装到了 params 这个对象中,然后使用 v-bind="params",将整个对象传给组件,组件接收的方式不变,比之前优雅很多

2.5 向组件中传多个参数-改进版2

const app = Vue.createApp({
data() {
return {
params : {
num1: 123,
num2: 456,
num3: 789
}
}
},
template:`
<div>
<test :params="params" />
</div>
`
}); app.component("test", {
props:['params'],
template:`
<div>{{params.num1}}</div>
<div>{{params.num2}}</div>
<div>{{params.num3}}</div>
`
});

这个例子较上个例子稍有不同,主组件使用对象的方式传递 :params="params",test 子组件也使用对象的方式接收 props:['params'],使用时使用 params.num1 的方式

这种方式较上一种方式,感觉更符合一般的编程习惯,根据个人喜好使用吧

2.6 参数的名称由多个单词组成

    const app = Vue.createApp({
data() {
return {
num: 123
}
},
template:`
<div>
<test :num-a="num" />
</div>
`
}); app.component("test", {
props:['numA'],
template:`
<div>{{numA}}</div>
`
});

当参数的名称由多个单词组成,官方的建议是,在组件标签中使用 小写 + ‘-’ 的方式命名,例如:num-a

但在子组件接收时,要使用驼峰命名法接收,例如:numA

哈哈,有点坑哦,要是写成 props:['num-a'] 是接收不到参数的

2.7 参数的计算(错误案例)

    const app = Vue.createApp({
data() {
return {
num: 10
}
},
template:`
<div>
<test :num="num" />
</div>
`
}); app.component("test", {
props:['num'],
template:`
<div>{{num}}</div>
<button @click="num = num + 1">num 加 1</button>
`
});

这个例子,我们接收到参数后,在子组件中将其自增

很不幸,自增没有成功,提示错误,大概意思是:这个参数是只读滴,不能修改 :(

那怎么办呢,看下面的例子

2.8 参数的计算(成功案例)

    app.component("test", {
props:['num'],
data() {
return {
myNum : this.num
}
},
template:`
<div>{{myNum}}</div>
<button @click="myNum = myNum + 1">num 加 1</button>
`
});

上一个例子告诉我们,父组件传过来的参数,到了子组件都是只读的,不能改变

因此我们换一个思路,我们在子组件中建一个自己的数据 myNum,然后把父组件传过来的数据作为初始值,然后去自增子组件的 myNum 数据

很明显是可以的

3. 综述

今天聊了一下 VUE3 的 组件传参,希望可以对大家的工作有所帮助,下一节我们继续讲组件的相关知识,敬请期待

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,每天更新Java干货。

4. 个人公众号

追风人聊Java,欢迎大家关注

VUE3 之 组件传参的更多相关文章

  1. Vue 子组件向父组件传参

    直接上代码 <body> <div id="counter-event-example"> <p>{{ total }}</p> & ...

  2. vue 父子组件传参

    父向子组件传参 例子:App.vue为父,引入componetA组件之后,则可以在template中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,component ...

  3. Vue(小案例_vue+axios仿手机app)_公共组件(路由组件传参)

    一.前言                    1.公共轮播图的实现                    2.组件传参,公共组件的实现 二.主要内容 1.公共轮播图的实现 (1)分析:当渲染不同的轮 ...

  4. Vue-admin工作整理(四):路由组件传参

    路由组件传参:如果在一个页面中,需要根据路由去获得参数,去对页面进行一些逻辑处理,首先可以通过this.$router来获取路由实例的参数,这样页面组件和路由就进行了耦合,为了进行分离,更大程度复用, ...

  5. VueJs(11)---vue-router(命名路由,命名视图,重定向别名,路由组件传参)

    vue-router 上篇文章讲了第一篇vue-router相关文章,文章地址:VueJs(10)---vue-router(进阶1) 一.命名路由 有时候,通过一个名称来标识一个路由显得更方便一些, ...

  6. vue子组件传参给父组件

    关于父组件传参给子组件,可以看我另一篇文章 教程开始: 我们要实现的效果是:在子组件的Input框输入,父组件中实时更新显示.(也就是把子组件中的数据传给父组件) 一.子组件代码 template部分 ...

  7. vue父组件传参给子组件

    其实组件之间传参有很多种方法: 1.通过本地存储 2.使用vuex状态管理 今天记录一下第三种方法 1.首页我们先创建一个项目(创建项目自行百度) 2.打开项目,在components文件夹下新建一个 ...

  8. 【vue】父向子组件传参、子组件向父传参

    1.父向子组件传参 App.vue为父,引入componetA组件之后,则可以在App.vue中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,componenta与 ...

  9. vue组件传参

    一.父子组件的定义 负值组件的定义有两种,我称为常规父子组件和特殊父子组件. 1.1.常规父子组件 将其他组件以import引入用自定义标签接收,在当前组件中component里注册该标签,页面上可以 ...

随机推荐

  1. java 数据类型:集合接口Collection之队列Queue:PriorityQueue ;Dequeue接口和ArrayDeque实现类:

    什么是Queue集合: Queue用于模拟队列这种数据结构,队列通常是"先进先出"(FIFO)的容器.队列的头部保存在队列中存放时间最长的元素,尾部保存存放时间最短的元素.    ...

  2. curl常用选项

    下载单个文件,默认将输出打印到标准输出中(STDOUT)中 curl http://www.centos.org 通过-o/-O选项保存下载的文件到指定的文件中:-o:将文件保存为命令行中指定的文件名 ...

  3. 【LeetCode】911. Online Election 解题报告(Python)

    [LeetCode]911. Online Election 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ ...

  4. Problem 2236 第十四个目标

    Problem 2236 第十四个目标 Accept: 4    Submit: 6Time Limit: 1000 mSec    Memory Limit : 32768 KB Problem D ...

  5. bugku的一道XFF转发代理服务器题 “本地服务器”

    X-Forwarded-For requests包内构造方式: X-Forwarded-For: client1, proxy1, proxy2

  6. kotlin+springboot+mybatis-puls+mysql搭建gradle-web工程

    kotlin+springboot+mybatis-puls+mysql搭建web工程 ​ 前段时间研究了spring security及OAuth2系列之后,本来打算研究spring的,但是部门发生 ...

  7. 什么是NaN?它的类型是什么?如何可靠的测试一个值是否等于NaN?

    NaN属性表示"不是数字"的值.这个特殊值是由于一个操作数是非数字的(例如"abc"/4)或者因为操作的结果是非数字而无法执行的. 虽然看起来很简单,但是NaN ...

  8. 你还不了解SpringSecurity吗?快来看看SpringSecurity实战总结~

    SpringSecurity简介:   权限管理中的相关概念 主体 principal: 使用系统的用户或设备或从其他系统远程登录的用户等等,简单说就是谁使用系统谁就是主体. 认证 authentic ...

  9. .net core使用rabbitmq消息队列

    看博文的朋友,本文有些过时了,还有些BUG,如果想了解更多用法,看看这篇吧:.net core使用rabbitmq消息队列 (二) 首先,如果你还没有安装好rabbitmq,可以参考我的博客: Ubu ...

  10. STL(1)vector

    STL(1) 1.vector vector是vector直译为"向量",一般说成"变长数组",也就是长度根据需要而自动改变的数组,有些题目需要开很多数组,往往 ...