今天就跟大家聊聊有關使用Vue2.0怎么實現組件傳值通訊,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
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:'' } }, components:{ JudgeStar }, computed:{ }, 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 }) } }, components:{ 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 :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>
看完上述內容,你們對使用Vue2.0怎么實現組件傳值通訊有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。