vue父子组件传值记录
admin
2024-01-18 05:08:52
0

之前父子组件传值不太熟悉,组件间传值要么用vuex,要么用sessionStorage缓存,但是sessionStorage感觉用多了不太好,缓存太多容易混淆,vuex还是比较好用,,但是用的过程中好像有个问题,记不得了,下次遇到再说

这次写自己的网站项目时因为页面有很多表格,加上布局什么的基本差不多,所以就想用公共组件,有区别的地方就是用slot插槽

不知道咋说,懒得写案例了,直接拿我这个页面说一下:

首先我是先创建了一个叫totalTableSort.vue的文件,这个文件作为公共组件,也算是子组件,写后面引入时相同的地方

在父组件使用时直接import引入注册组件后使用即可

父组件向子组件传值

在父组件使用时,上面写的:porpsPageTitle和后面其他的就是要从父组件传递向子组件的值,例如:porpsPageTitle就是我要传递的本页面的标题名

此时父组件传值就完成了,接下来在子组件使用

如下,props与data同级,在props里面直接写上即可,我这里是在data里面重新赋值了一下,使用时就是模板语法直接用data里的pageTitle即可,如果不进行重新赋值到data直接使用propsPageTitle也是可以的,因为props里的是传递下来的,不可以重新改变这个值,所以习惯重新在data里面写一下

{{ pageTitle }}

data() {return {pageTitle: this.propsPageTitle,}; }, props: {propsPageTitle: "", //页面标题 },

其他情况

大部分时候需要传递从其他地方请求来的数值,又因为这个传值时异步进行的,有时候数值还没请求到值就传过去了,如果在子页面的mounted里面给data里的变量赋值,例如我要写this.showDataList=this.porpsShowDataList,本意是想让传过来的“显示的列表”赋给子页面的showDataList,但是这时因为值还没有请求到,然后就给showDataList赋了个空值,导致数据请求来之后也不能重新给页面数据渲染上

有人可能说那直接拿propsShowDataList用不就行了,也不是不可以,但是如果需要更改showDataList的话就没有办法了,因为我这里是使用showDataList控制显示的数据,需要经常变化,所以自然是不行

解决办法: 这时可以使用vue里的watch进行监听propsShowDataList值的变化,因为vue是响应式的,在父组件请求数据完成后传递的请求的值就会跟着变化,此时坚挺到propsShowDataList的变化就可以给showDataList重新赋值渲染,如下,监听哪个值前面就写哪个值,newData是新监听到变化后得值,oldData是之前的值

watch: {propsShowDataList(newData, oldData) {console.log("监听显示列表", newData, oldData);this.showDataList = newData;},
}, 

子组件向父组件传值

2022/3/25用到子组件调父组件方法了,顺便来写一下

使用$emit调用父组件传参,可以在父组件直接使用

这里我有一个导入数据的按钮,是在标题头上,因为页面标题这个玩意我这里很多页面除了内容不一样,样式排版什么都一样,所以就写在子组件上了,数据就在父组件获取,然后使用上面的父组件向子组件传值获取,这个时候点击导入数据之后,把文件数据写入数据库需要再调用一次父组件的getData()方法

这里可以在写入成功后使用$emit去调用父组件方法,$emit后面有两个参数,第一个是随便取一个方法名,例如我这里写的是parGetData意为父组件得getData方法

然后在父组件用@绑定子组件调用的函数,使用@子组件方法名="要调用的方法",这样就可以在子组件调用父组件的方法

$emit的第二个参数是调用父组件方法时传入的值,这里将上面的改一下

调用时改成这样

绑定的不变依然是@parGetData="getData"

在父组件的getData()方法接收一个参数,我这里用val表示,然后打印一下val

完事子组件调用时,就会将后面写的要传入的参数传到父组件的getData去,在getData可以操作这个传来的值,这就是子组件向父组件传值

好像之前还看到过比较离谱的更深层的传值(祖父或者曾祖父级别的传值),回头遇到再写

最后

整理了75个JS高频面试题,并给出了答案和解析,基本上可以保证你能应付面试官关于JS的提问。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

相关内容

热门资讯

银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...
君赛生物港股IPO,增聘兴证国... 跟丰宜科技一样,正冲刺港股IPO的上海君赛生物股份有限公司(简称“君赛生物”)增聘一位整体协调人。 ...
圣邦股份明日上市:暗盘涨24%... 雷递网 雷建平 6月25日 圣邦微电子(北京)股份有限公司(简称:“圣邦股份”,股票代码:“0366...
科技“吃肉”,券商跟着“喝汤”... 当科技持续成为市场核心主线,押中硬科技项目的券商也成为被追逐的焦点。 6月24日,半导体零部件概念股...