backgroundWhen you open the product details on some shopping mall web pages, there will be a counter to select the purchase quantity. Such a timer will not only be displayed on the product details page but also in the shopping cart. Then the timer can be encapsulated into a component for better reuse and later maintenance. Landing code<template> <div class="xtx-numbox"> <div class="label"><slot /></div> <div class="numbox"> <a href="javascript:;" @click="handleSub(-1)">-</a> <input type="text" readonly :value="num" /> <a href="javascript:;" @click="handleSub(1)">+</a> </div> </div> </template> <script> // Third-party method useVModel to implement two-way binding import { useVModel } from '@vueuse/core' export default { name: 'XtxNumbox', props: { modelValue: { type: Number, default: 1 } }, setup(props, { emit }) { //The useVModel method receives three parameters, // Parameter 1: custom property props receives data passed by the parent component through v-model two-way binding // Parameter 2: data to be passed in props // Parameter 3: emit bound data needs to notify the parent component through the emit event const num = useVModel(props, 'modelValue', emit) const handleSub = n => { if (n < 0) { num.value -= 1 if (props.modelValue === 1) { num.value = 1 } } else { num.value += 1 } } return { handleSub, num } } } </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 <XtxNumbox v-model="num">Quantity</XtxNumbox> Effect 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:
|
<<: MySQL learning tutorial clustered index
The fixed layout of the page header was previousl...
Table of contents Overview 1. Separation of front...
Table of contents 1. What is a hook? 2. Why does ...
Recently, Oracle announced the public availabilit...
Uninstall MySQL 1. In the control panel, uninstal...
1. The concept of css: (Cascading Style Sheet) Ad...
A Brief Discussion on the Navigation Window in If...
Introduction: When using MySQL to create a table,...
When using MySQL 5.7, you will find that garbled ...
vue scaffolding -> vue.cli Quickly create a la...
The project scaffolding built with vue-cli has al...
1. Arrow Function 1. Take advantage of the fact t...
When position is absolute, the percentage of its ...
Achieve results Implementation Code html <div ...
mysql batch delete large amounts of data Assume t...