feat: 步进器组件封装

This commit is contained in:
duanshuwen
2025-07-15 11:05:25 +08:00
parent 7f270dafe8
commit b31b04f2e2
19 changed files with 245 additions and 38 deletions

View File

@@ -0,0 +1,52 @@
"use strict";
const common_vendor = require("../../common/vendor.js");
const common_assets = require("../../common/assets.js");
const _sfc_main = {
__name: "index",
props: {
modelValue: {
type: Number,
default: 1
},
min: {
type: Number,
default: 1
},
max: {
type: Number,
default: 100
}
},
emits: ["update:modelValue"],
setup(__props, { emit: __emit }) {
const props = __props;
const emit = __emit;
const value = common_vendor.ref(props.modelValue);
const decrease = () => {
if (value.value === 1)
return;
if (value.value > props.min) {
value.value--;
emit("update:modelValue", value.value);
}
};
const increase = () => {
if (value.value < props.max) {
value.value++;
emit("update:modelValue", value.value);
}
};
return (_ctx, _cache) => {
return {
a: common_assets._imports_0$10,
b: common_vendor.o(decrease),
c: common_vendor.t(value.value),
d: common_assets._imports_1$4,
e: common_vendor.o(increase)
};
};
}
};
const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__scopeId", "data-v-52e20cb2"]]);
wx.createComponent(Component);
//# sourceMappingURL=../../../.sourcemap/mp-weixin/components/Stepper/index.js.map

View File

@@ -0,0 +1,4 @@
{
"component": true,
"usingComponents": {}
}

View File

@@ -0,0 +1 @@
<view class="stepper-wrapper data-v-52e20cb2"><image class="stepper-btn stepper-btn-minus data-v-52e20cb2" src="{{a}}" mode="aspectFill" bindtap="{{b}}"></image><text class="stepper-text data-v-52e20cb2">{{c}}</text><image class="stepper-btn stepper-btn-plus data-v-52e20cb2" src="{{d}}" mode="aspectFill" bindtap="{{e}}"></image></view>

View File

@@ -0,0 +1,44 @@
/**
* 这里是uni-app内置的常用样式变量
*
* uni-app 官方扩展插件及插件市场https://ext.dcloud.net.cn上很多三方插件均使用了这些样式变量
* 如果你是插件开发者建议你使用scss预处理并在插件代码中直接使用这些变量无需 import 这个文件方便用户通过搭积木的方式开发整体风格一致的App
*
*/
/**
* 如果你是App开发者插件使用者你可以通过修改这些变量来定制自己的插件主题实现自定义主题功能
*
* 如果你的项目同样使用了scss预处理你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
*/
/* 颜色变量 */
/* 行为相关颜色 */
/* 文字基本颜色 */
/* 背景颜色 */
/* 边框颜色 */
/* 尺寸变量 */
/* 文字尺寸 */
/* 图片尺寸 */
/* Border Radius */
/* 水平间距 */
/* 垂直间距 */
/* 透明度 */
/* 文章场景相关 */
.stepper-wrapper.data-v-52e20cb2 {
display: flex;
align-items: center;
}
.stepper-btn.data-v-52e20cb2 {
width: 24px;
height: 24px;
cursor: pointer;
}
.stepper-btn-minus.data-v-52e20cb2 {
margin-right: 10px;
}
.stepper-btn-plus.data-v-52e20cb2 {
margin-left: 10px;
}
.stepper-text.data-v-52e20cb2 {
font-size: 16px;
color: #333;
}