vue饿了么(六)--ratingselect组件 & 父组件food.vue和子组件ratingselect.vue通信

ratingselect.vue

<template>
	<div class="ratingselect">
		<div class="rating-type" border-1px>
			<span @click='select(2,$event)' class="block positive" :class="{'active':mySelectType===2}">{{desc.all}}<span class="count">{{ratings.length}}</span></span>
			<span @click='select(0,$event)' class="block positive" :class="{'active':mySelectType===0}">{{desc.positive}}<span class="count">{{positives.length}}</span></span>
			<span @click='select(1,$event)' class="block negative" :class="{'active':mySelectType===1}">{{desc.negative}}<span class="count">{{negatives.length}}</span></span>
		</div>
		<div @click='toggleContent' class="switch" :class="{'on':myOnlyContent}">
			<span class="icon-check_circle"></span>
			<span class="text">只看有内容的评价</span>
		</div>
	</div>
</template>
select(type,event) {
	if(!event._constructed){
		return;
	}
	this.mySelectType = type;
	this.$emit('increment','selectType',this.mySelectType);
},
toggleContent() {
	if(!event._constructed){
		return;
	}
	this.myOnlyContent = !this.myOnlyContent;
	this.$emit('increment','onlyContent',this.myOnlyContent);
}

因为不允许改变props里面的值,这里我采用的方法是在data中重新定义,再讲改变后的结果通过$emit传给父组件

data() {
	return {
		mySelectType:this.selectType,
		myOnlyContent:this.onlyContent
	}
},

父组件的接收

<ratingselect @increment="incrementTotal" :selectType='selectType' :onlyContent='onlyContent' :desc='desc' :ratings='food.ratings'></ratingselect>
incrementTotal(type,data) {
	this[type]=data;
	this.$nextTick(() => {
		this.scroll.refresh();
	});
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值