Vue implements the packaging and use of components to control the number of goods

Vue implements the packaging and use of components to control the number of goods

The encapsulation and use of Vue's control product quantity component is for your reference. The specific contents are as follows

To achieve the effect

Control the number of products component package 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 }) {
    // Bidirectional binding of data controlled by a third-party method const num = useVModel(props, 'modelValue', emit)
    // Control the change operation of product data const toggle = (n) => {
      if (n < 0) {
        // Subtract one operation if (num.value > 1) {
          num.value -= 1
        }
      } else {
        // Add one operation 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>

Use in parent component

<Numbox v-model='num' >Quantity</XtxNumbox>
setup(){
 //The number of products//The default value is 1
  const num = ref(1)
  return {
    num 
  }
}

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Vue implements the quantity prompt function of the product classification menu

<<:  Differences between MySQL MyISAM and InnoDB

>>:  Docker builds cluster MongoDB implementation steps

Recommend

Detailed Analysis of Event Bubbling Mechanism in JavaScript

What is bubbling? There are three stages in DOM e...

How to improve Idea startup speed and solve Tomcat log garbled characters

Table of contents Preface Idea startup speed Tomc...

Examples of two ways to implement a horizontal scroll bar

Preface: During the project development, we encou...

React hooks introductory tutorial

State Hooks Examples: import { useState } from &#...

Introduction to MySQL database performance optimization

Table of contents Why optimize? ? Where to start?...

A brief discussion on the three major issues of JS: asynchrony and single thread

Table of contents Single thread asynchronous Sing...

How to Dockerize a Python Django Application

Docker is an open source project that provides an...

Implementing timed page refresh or redirect based on meta

Use meta to implement timed refresh or jump of th...

Analyzing the four transaction isolation levels in MySQL through examples

Preface In database operations, in order to effec...

Markup validation for doctype

But recently I found that using this method will c...

Zabbix monitoring docker application configuration

The application of containers is becoming more an...

Summary of fragmented knowledge of Docker management

Table of contents 1. Overview 2. Application Exam...

Docker Gitlab+Jenkins+Harbor builds a persistent platform operation

CI/CD Overview CI workflow design Git code versio...

React and Redux array processing explanation

This article will introduce some commonly used ar...