Vue2.0 组件传值通讯的示例代码
网络编程 2021-07-04 18:33www.168986.cn编程入门
本篇文章主要介绍了Vue2.0 组件传值通讯的示例代码,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
在Vue项目中,我们经常把某个功能模块封装起来,形成组件,下次调用时非常方便,也是在一些循环中进行dom操作的一种较好方式。
本次我想以一个评价组件来说一下组件的事件和参数是怎样传递的,如何完成的组件通讯。
示例如下
这里先说一下组件设计思路
明确整个功能场景,找出存在的事件操作,此例是一个简单的评价功能,即点击某一个星星时左边以及当前为选中的黄色星,右边为未选中的白色星。
确定可复用的组件,即具有重复操作的模块,这里明显的每一个星星为一个可复用组件, 其实还有个星星变成白色和黄色也是一个小组件,这种在具体写的时候觉得可以再分即可。
至此一个划分了三个组件JudgeOf、JudgeStar、StarImg
这里需要明确的是,在大多数的组件通讯中,父组件往子组件传递的都是数据,子组件往父组件传递的才是事件,
我们姑且称父到子走的是一个数据流,子到父走的是一个事件流,了解这一点基本可以很好的了解组件通讯的情况。
JudgeOf组件
基本的外框,循环starList构成三个评分选项。向子组件传递选项名字,和当前选项的索引
<template> <div> <div class="judge-modal" @click="cancel"></div> <div class="judge"> <br> <div class="text-center font16">评价</div> <judge-star v-for="item,index in starList" :key="index" @judge="judge" :name="item.name" :index="index" ></judge-star> <br> <div class="box container text-left"> <span class="icon-i"></span> 评价内容 </div> <div class="bgfff container font14"> <textarea placeholder="请输入您的评价,方便我们改进,谢谢!" type="textarea" class="textarea" rows="6" v-model="judgeTxt"></textarea> </div> <div class="container"> <br> <div class="btn btn_block text-center" @click="submit">提交</div> </div> </div> </div> </template> <script> import JudgeStar from './judgeStar.vue' export default{ data(){ return{ starList:[ {name:'服务态度',key:'evaluate.serviceStarLevel'}, {name:'责任感',key:'evaluate.dutyStarLevel'}, {name:'准时度',key:'evaluate.onTimeStarLevel'}, ], evaluate:[], judgeTxt:'' } }, ponents:{ JudgeStar }, puted:{ }, methods:{ cancel(){ this.$emit('cancel') }, submit(){ let data = ''; this.starList.forEach((val,index)=>{ data =`${val.key}:${this.evaluate[index]}` console.log(data) }); }, judge(data){ this.evaluate[data[0]]=data[1]; } } } </script>
JudgeStar组件
在这里注册一个chooseIndex,当点击某一个星星时,StarImg组件emit当前星星的index,JudgeStar组件中接收此参数并赋值给chooseIndex,StarImg里面watch这个参数,大于index表明没有被选中,反之则为选中,
<template> <div class="flex_cont container"> <div class="flex_item name">{{name}}</div> <div class="flex_item"> <star-img @choose="choose" v-for="item,index in starArr" :key="index" :chooseIndex="chooseIndex" :index="index"></star-img> </div> </div> </template> <script> import StarImg from './starImg.vue' export default{ props:{ name:String, index:'' }, data(){ return{ chooseIndex:4, starArr:Array.from({ length: 5 }) } }, ponents:{ StarImg }, mounted(){ this.$emit('judge',[this.index,this.chooseIndex+1]); }, methods:{ choose(data){ this.chooseIndex = data; this.$emit('judge',[this.index,this.chooseIndex+1]); } } } </script>
StarImg组件
观察chooseIndex值的变化
<template> <i style="margin: 0 3px;" :class="icon" @click="choose"></i> </template> <script> export default{ props:{ index:Number, //当前星星的索引 chooseIndex:Number //选中星星的索引 }, data(){ return{ icon:'icon-star' } }, watch:{ //大于index表明没有被选中,反之则为选中, chooseIndex:function () { if(this.chooseIndex>=this.index){ this.icon = 'icon-star' } else { this.icon = 'icon-star2' } }, }, methods:{ choose(){ /所选星星最大索引/ this.$emit('choose',this.index) } }, created(){ } } </script>
一下
- 父组件通过v-bind:绑定参数传给子组件,子组件通过props接受这个参数。
- 在组件的最底层开始写事件,由最底层组件逐步向上$emit事件流,并携带相应参数,在父组件内完成总的数据处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程