我想編寫一個數(shù)量的加減組件,類似于這樣,點擊加號增加數(shù)量,點擊減號減少數(shù)量。
問題是加號我需要做限制,每一行都不能大于它本來的數(shù)量,這個數(shù)量是從list里面取出來的,是動態(tài)的,現(xiàn)在我使用v-bind到一個自定義屬性上,然后取出來,
<div class="num-container">
<span class="num-cicle num-minus" :data-num="goods.number" @click="count(goods,-1)">-</span>
<span>{{goods.number}}</span>
<span class="num-cicle num-plus" :data-num="goods.number" @click="count(goods,1,$event)">+</span>
</div>
方法
count(val,num,e){
if(num>0){
let tempValue=val.number+1;
if(tempValue>e.target.getAttribute('data-num')){
Toast("數(shù)量不能大于最大簽收數(shù)量")
}else{
val.number++;
}
}else{
if(val.number > 0){
val.number--;
}else{
Toast("數(shù)量不能再少了")
}
}
}
但是由于是v-bind,所以我每次取出來的值都是改完了之后的值,無法達到我想要的效果。這里的難點是每一行的數(shù)量都是從list里取出來的動態(tài)值,我通過代碼更改了之后if這個條件永遠無法滿足,各位有什么好辦法嗎?
組件設(shè)計的有點問題,num-container 這個組件應(yīng)該接受兩個屬性,一個 max-num 表示數(shù)量的最大值,一個是 num 表示現(xiàn)在展示的值,然后通過 .sync 將 num 屬性做一個雙向綁定
改寫一下你的代碼,思路如下:
// num-container.vue
<template>
<div class="num-container">
<span class="num-cicle num-minus" @click="count(-1)">-</span>
<span>{{ num }}</span>
<span class="num-cicle num-plus" @click="count(1)">+</span>
</div>
</template>
<script>
export default {
props: ['num', 'maxNum'],
methods: {
count (val) {
const nextNum = this.num + val
if (nextNum > this.maxNum) {
Toast("數(shù)量不能大于最大簽收數(shù)量")
} else if (nextNum < 0) {
Toast("數(shù)量不能再少了")
} else {
// num 與父組件進行了雙向綁定,通過 $emit 來更新
this.$emit('input', nextNum)
}
}
}
}
</script>
然后 num-container 組件就可以這么用了:
<template>
<num-container
v-for="goods in list"
:num.sync="goods.number"
:max-num="goods.maxNumber">
</num-container>
</template>
<script>
export default {
created () {
// 需要給 list 中的每一列加個 maxNumber 屬性
this.list = this.list.map(item => ({ ...item, maxNumber: item.number }))
}
}
</script>
當(dāng)然要解決你上面的問題,最簡單的方法,就是像我上面的 created () 函數(shù)那樣,在 goods 對象上加個 maxNumber 的屬性,然后每次判斷都只去判斷 maxNumber。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。