Vue实现控制商品数量组件封装及使用
短信预约 -IT技能 免费直播动态提醒
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
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341