您好,登錄后才能下訂單哦!
這篇文章主要介紹Vue如何實現控制商品數量組件,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
要實現效果
控制商品數量組件封裝 Numbox
<template> <div class="xtx-numbox"> <div class="label"> <slot /> </div> <div class="numbox"> <a href="javascript:;" @click='toggle(-1)'>-</a> <input type="text" readonly :value="num"> <a href="javascript:;" @click='toggle(1)'>+</a> </div> </div> </template> <script> import { useVModel } from '@vueuse/core' export default { name: 'XtxNumbox', props: { modelValue: { type: Number, default: 1 }, inventory: { type: Number, required: true } }, setup (props, { emit }) { // 基于第三方的方法控制數據的雙向綁定 const num = useVModel(props, 'modelValue', emit) // 控制商品數據的變更操作 const toggle = (n) => { if (n < 0) { // 減一操作 if (num.value > 1) { num.value -= 1 } } else { // 加一操作 if (num.value < 10) { num.value += 1 } } } return { num, toggle } } } </script> <style scoped lang="less"> .xtx-numbox { display: flex; align-items: center; .label { width: 60px; color: #999; padding-left: 10px; } .numbox { width: 120px; height: 30px; border: 1px solid #e4e4e4; display: flex; > a { width: 29px; line-height: 28px; text-align: center; background: #f8f8f8; font-size: 16px; color: #666; &:first-of-type { border-right: 1px solid #e4e4e4; } &:last-of-type { border-left: 1px solid #e4e4e4; } } > input { width: 60px; padding: 0 5px; text-align: center; color: #666; } } } </style>
在父組件使用
<Numbox v-model='num' >數量</XtxNumbox> setup(){ // 商品的數量 // 默認值是1 const num=ref(1) return { num } }
以上是“Vue如何實現控制商品數量組件”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。