基于Vue和uni-app的增强型多选框Checkbox组件开发

news2025/1/22 12:22:15

基于Vue和uni-app的增强型多选框(Checkbox)组件开发

摘要

随着前端技术的不断发展和用户体验要求的提升,传统的Checkbox组件已不能满足所有需求。本文介绍了一种基于Vue和uni-app的增强型多选框(Checkbox)组件的开发过程。该组件不仅提供了基本的复选功能,还通过数据驱动、支持页面正反向传值等特性,进一步增强了组件的灵活性和可重用性。

图片

一、引言

Checkbox组件在前端开发中扮演着重要角色,它允许用户选择多个选项,是表单交互中不可或缺的元素。然而,传统的Checkbox组件往往功能单一,无法满足复杂多变的前端需求。因此,开发一种增强型的Checkbox组件成为了必要。

二、组件需求分析与设计

  1. 数据驱动:组件应该能够通过数据驱动,即组件的状态和行为应该由数据决定,而不是通过直接操作DOM元素来实现。

  2. 多选功能:组件应该支持多选操作,允许用户选择多个选项。

  3. 页面正反向传值:组件应该能够支持页面正反向传值,即能够将组件的状态传递给父组件,同时也能够接收父组件传递的数据。

  4. 易于扩展和定制:组件应该具有良好的扩展性和可定制性,方便开发者根据具体需求进行二次开发。

   效果图如下:

图片

图片

图片

图片

三、示例代码

 
使用方法
<!-- 多选组件  checkData:多选数据  @change:多选事件  -->
<cc-checkView :checkData="items" @change="checkboxChange"></cc-checkView>

HTML代码实现部分

<template>
    <view>
        <!-- 多选组件  checkData:多选数据  @change:多选事件  -->
        <cc-checkView :checkData="items" @change="checkboxChange"></cc-checkView>

        <button class="botBtn" type="primary" @click="submitBtnClick">完成</button>

    </view>
</template>

<script>
    export default {

        data() {

            return {
                selArr: [],
                items: [{
                        value: '无配置',
                        name: '无配置',
                        checked: false

                    },
                    {
                        value: '空调',
                        name: '空调',
                        checked: false

                    },
                    {
                        value: '沙发',
                        name: '沙发',
                        checked: false
                    },
                    {
                        value: '衣柜',
                        name: '衣柜',
                        checked: false

                    },
                    {
                        value: '宽带',
                        name: '宽带',
                        checked: false

                    },
                    {
                        value: '电视',
                        name: '电视',
                        checked: false

                    },
                    {
                        value: '冰箱',
                        name: '冰箱',
                        checked: false

                    },
                    {
                        value: '床',
                        name: '床',
                        checked: false

                    },
                    {
                        value: '洗衣机',
                        name: '洗衣机',
                        checked: false

                    }

                ]
            };
        },
        onLoad(e) {

            // 获取正向传值
            if (typeof(e.obj) === 'string') {

                let selArr = e.obj.split(',');

                // 设置已经勾选的数据
                for (let item of this.items) {

                    if (selArr.includes(item.name)) {
                        this.$set(item, 'checked', true);
                    } else {
                        this.$set(item, 'checked', false);
                    }
                }

            }
            console.log("正向传值" + e.obj);
        },
        methods: {
            // 多选事件
            checkboxChange: function(e) {

                this.selArr = e.detail.value;
                console.log(this.selArr);
            },
            submitBtnClick: function(e) {

                console.log(this.selArr);
                this.$eventHub.$emit('fire', this.selArr);

                uni.navigateBack({
                    animationDuration: 20
                });
            }
        }
    };
</script>

<style>
    .uni-list-cell {
        justify-content: flex-start;
        width: 100%;
        background-color: #8a6de9;
    }

    .mycheckBox {
        margin-left: 24px;
        margin-right: 10px;
        margin-top: 50rpx;
    }

    .botBtn {
        margin-top: 36px;
        width: 89%;
    }
</style>

四、组件应用

在父组件中引入并使用增强型多选框组件,通过v-model指令实现双向数据绑定,并通过监听@change事件处理多选事件。

 

五、总结与展望

本文介绍了基于Vue和uni-app的增强型多选框组件的开发过程。该组件通过数据驱动、支持页面正反向传值等特性,提高了组件的灵活性和可重用性。未来,我们可以继续探索组件的更多可能性和应用场景,如支持条件筛选、异步加载数据等,以满足更复杂的前端需求。同时,也可以考虑将该组件开源,为更多的开发者提供便利。

项目下载地址:

https://ext.dcloud.net.cn/plugin?id=12979

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1681029.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一文了解人工智能AI、大模型、AI大模型、ChatGPT、GPT-4、OpenAI、Claude 3...

AI是什么&#xff1f; 首先&#xff0c;AI是什么&#xff1f; 人工智能&#xff08;Artificial Intelligence&#xff09;&#xff0c;英文缩写为AI。 是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。 简单来说就是模拟人类行为…

Linux文件系统详解

&#x1f30e;Linux文件系统 文章目录&#xff1a; Linux文件系统 简单认识磁盘 文件系统       磁盘线性结构抽象       文件系统存储方法 inode Table         inode Bitmap         Data Block         Block Bitmap         …

Python 全栈体系【四阶】(四十五)

第五章 深度学习 十、生成对抗网络&#xff08;GAN&#xff09; 1. 图像生成技术概述 1.1 什么是图像生成技术 图像生成技术是指利用机器学习或深度学习等人工智能技术&#xff0c;通过训练模型来生成逼真的图像。这些技术可以根据给定的输入&#xff0c;生成与真实图像相似…

MySQL基础--SQL优化

插入数据 insert 优化 批量插入 手动提交事务 主键顺序插入 大批量插入数据 如果一次性需要大批量插入数据&#xff0c;使用 insert 语句插入性能较低&#xff0c;此时可以使用 MySQL 数据库提供的 load 指令插入&#xff0c;操作如下&#xff1a; 主键优化 在 InnoDB 存储引擎…

DiffusionModel-DDIM推导+代码详解

视频deep_thoughts 论文https://arxiv.org/abs/2010.02502 参考https://blog.csdn.net/weixin_47748259/article/details/137018607 DDPM生成过程就是把每一步都看作高斯分布的形式&#xff0c;所以采样过程和前向加噪过程的链条长度是一致的。DDIM就是在思考能不能够加速这个采…

小程序(四)

十四、分包加载 &#xff08;一&#xff09;普通分包与主包 随着项目越来越大&#xff0c;为了用户更好的体验&#xff0c;小程序引用了分包技术&#xff0c;分包技术将tabBar页面及一些全局使用的静态资源&#xff0c;放到主包中&#xff0c;开发者可以根据需要添加分包&…

典型芯片的载波馈通(本振泄露)问题

零中频的本振泄露会降低发射机的EVM&#xff0c;本文我们将会对SX1255和AD9361的本振泄露问题进行简单的讨论。 1.SX1255载波馈通问题 表1.1中的-8dBc测试结果的前提是PAD输出功率为-5dBm&#xff0c;那么此时根据-8dBc的载波本振抑制可以知道Driver输出的载波馈通功率为-13dB…

python接口测试之tokensession的处理

使用python语言来进行实现&#xff0c;在这里我们使用第三方的库requests&#xff0c;需要单独的安装下&#xff0c;安装的命令是&#xff1a; pip install -U requests 见安装的截图&#xff1a; 安装成功后&#xff0c;如果可以在正常的导入&#xff0c;说明安装OK&#xf…

Linux 通过关键字查找文件

按文件名查找 find 路径 -name “文件名” 查找当前目录下的所有mk文件 find . -name "*.mk"按关键字查找 find 路径 -name “文件名” | xargs grep -n “关键字” 参数&#xff1a; xargs 是给命令传递参数的一个过滤器&#xff0c;也是组合多个命令的一个工具 -n…

macOS Ventura 13如何设置定时重启(命令行)

文章目录 macOS Ventura 13如何设置定时重启(命令行)前言具体设置步骤及命令解释其他 macOS Ventura 13如何设置定时重启(命令行) 前言 由于升级 macOS 13 Ventura 之后&#xff0c;之前在节能里面通过鼠标点击设置开机关机的方法不能用了&#xff0c;现在只能用命令设置开机…

视频下载器 - 网页视频自动嗅探2.2.4

【应用名称】&#xff1a;视频下载器 - 网页视频自动嗅探 【适用平台】&#xff1a;#Android 【软件标签】&#xff1a;#Video #Downloader 【应用版本】&#xff1a;2.2.4 【应用大小】&#xff1a;33MB 【软件说明】&#xff1a;软件升级更新。支持多种格式的看片神器&am…

一.使用MySQL Workbench连接mysql数据库

一.使用MySQL Workbench连接数据库 MySQL Workbench这是MySQL官方主推的数据库可视化工具。 它提供了管理MySQL数据库,设计模型,进行SQL开发和管理的功能。主要功能包括: 数据库设计:可以通过直观的GUI创建EER模型,生成数据库结构。 SQL开发:提供代码编辑器,可以方便编写和执行…

番外篇 | 一文读懂卷积神经网络(CNN)的基础概念及原理

前言:Hello大家好,我是小哥谈。卷积神经网络(Convolutional Neural Network,CNN)是一种深度学习模型,主要用于图像识别和计算机视觉任务。本文旨在对卷积神经网络进行详细的讲解,从基本原理到实际应用,帮助读者全面了解CNN的工作原理、优势和基本组成等,以及其在现实生…

绝地求生:29.2商城更新内容预览:挣脱尘网通行证,经典皮肤返场,空投活动

就在今天历经9小时维护&#xff0c;29.2版本终于上线&#xff0c;柠檬茶带大家一起看看&#xff0c;这次游戏里都更新了哪些内容吧。 挣脱尘网通行证 豪华版&#xff1a;$14.99 普通版&#xff1a;$4.99 豪华版比普通版多10级升级券和2套生存者宝箱 分支一 分支二 分支三 额外…

java入门1.1.2

前言&#xff1a; 第一&#xff1a;一坨垃圾的迭代&#xff0c;还是垃圾 第二&#xff1a;本内容为对类&#xff0c;对象&#xff0c;构造函数的最新抽象理解 正片 先将类&#xff0c;对象&#xff0c;还要构造函数翻译成英文 class&#xff0c;object&#xff0c;construc…

【氮化镓】高电容密度的p-GaN栅电容在高频功率集成中的应用

这篇文章是香港科技大学Kevin J. Chen等人与台积电M.-H. Kwan等人关于高电容密度的p-GaN栅电容在高频功率集成中的应用研究。 文章详细介绍了p-GaN栅电容的设计、特性和在高频功率集成中的应用。通过实验数据和理论分析&#xff0c;文章展示了p-GaN栅电容在实现高电容密度、低…

ChatGpt生成网页应用,实现上传文件到服务器并保存上传记录的功能

使用 HTML 和 JavaScript 实现文件上传功能 1. 简介 在现代 web 开发中&#xff0c;实现文件上传功能是一个常见的需求。本文将介绍如何使用 HTML、CSS 和 JavaScript 创建一个支持 .obj 和 .jpg 文件上传的网页应用&#xff0c;并且展示上传进度以及上传完成后的文件信息。用…

AMD W7900本地大型语言模型的微调

GenAI-contest/01-LLM_Fine-tuning at main amd/GenAI-contest (github.com) 大型语言模型&#xff08;LLMs&#xff09;在大量的文本数据上进行训练。因此&#xff0c;它们能够生成连贯且流畅的文本。Transformer架构是所有LLMs的基础构建块&#xff0c;它作为底层架构&…

EasyCVR智慧校园建设中的关键技术:视频汇聚智能管理系统应用

一、引言 随着信息技术的迅猛发展&#xff0c;智慧校园作为教育信息化建设的重要组成部分&#xff0c;对于提升校园安全、教学效率和管理水平具有重要意义。本文旨在介绍智慧校园视频管理系统的架构设计&#xff0c;为构建高效、智能的校园视频监控系统提供参考。 二、系统整…