web前端之vue+element+select实现多选、两个数组排序、保持源数据、查找索引、过滤、克隆、复制、findIndex、filter

news2024/11/13 9:43:10

MENU

  • 前言
  • 效果图
  • template
  • style
  • JavaScript


前言

1、代码段是一个Vue组件的模板、脚本和样式的完整实现。它结合element的一些组件(如el-select和el-radio-group),实现一个带有下拉选择、多选功能以及可选择“是/否”状态的组件。
2、组件实现一个复杂的选择和管理界面,用户可以从下拉列表中选择多个选项,选择后每个选项会在下方的radio-box中显示,并可以选择对应的“是/否”状态。通过handleCancel方法,用户可以移除某个选项,changeSelect方法则负责更新选项列表和状态。整个组件逻辑清晰,使用element提供的组件实现良好的用户交互体验。


效果图

新增


默认


激活


template

代码

<template>
  <div class="box">
    <el-select
      class="select"
      v-model="formData.val"
      multiple
      collapse-tags
      collapse-tags-tooltip
      :max-collapse-tags="2"
      placeholder="请选择"
      @change="changeSelect"
    >
      <el-option
        v-for="item in options"
        :key="item.id"
        :label="item.label"
        :value="item.id"
      />
    </el-select>

    <div class="radio-box">
      <div v-for="item in valList" :key="item.id">
        <span @click="handleCancel(item)">{{ item.label }}</span>
        <el-radio-group v-model="item.isType">
          <el-radio :label="true"></el-radio>
          <el-radio :label="false"></el-radio>
        </el-radio-group>
      </div>
    </div>
  </div>
</template>

解析

1、<el-select>
1.1、v-model绑定formData.val,实现双向数据绑定。
1.2、multiple属性允许多选。
1.3、collapse-tagscollapse-tags-tooltip配合使用,提供选择项的折叠展示,超出指定数量时显示提示。
1.4、max-collapse-tags="2"设置最多折叠显示2个选项,其他选项折叠。
1.5、@change="changeSelect"监听选择变化事件,调用changeSelect方法。
1.6、v-for="item in options"遍历options数组,生成el-option子组件,item.id作为每个选项的唯一key,item.label作为显示的文本,item.id作为选项的值。


2、<div class=“radio-box”>
2.1、v-for="item in valList"遍历valList数组,生成每个选项的名称和对应的单选框组。
2.2、@click="handleCancel(item)"绑定点击事件,点击名称时会触发handleCancel方法,移除该选项。
2.3、el-radio-group使用v-model绑定item.isType,控制“是/否”状态。
2.4、el-radio组件的label分别设置为true或false,对应“是”和“否”。


style

代码

.box {
  margin: 0;
  padding: 28px;
  box-sizing: border-box;

  > .select {
    width: 100%;
  }

  .radio-box {
    width: 100%;

    > div {
      width: 100%;
      display: flex;
      justify-content: space-between;
      align-items: center;

      > span {
        cursor: pointer;
      }
    }
  }
}

解析

.box
1、包裹整个组件的容器。
2、设置padding: 28px;确保内部元素有一定的间距。
3、box-sizing: border-box;确保padding包含在元素宽度和高度内。


.select
1、将el-select设置为100%宽度,适应父容器。


.radio-box
1、包含所有单选框组的容器。
2、内部的每个div(对应valList中的一个选项)设置为flex布局,子元素(选项名称和单选框)水平排列。
3、> spancursor: pointer;使光标在悬停时变为指针样式,提示用户该元素可点击。


JavaScript

代码

const runClone = val => JSON.parse(JSON.stringify(val));

export default {
  name: 'demo',
  data() {
    return {
      formData: {
        val: []
      },
      options: [
        { id: 6, label: 'option-6', isType: true },
        { id: 2, label: 'option-2', isType: true },
        { id: 1, label: 'option-1', isType: true },
        { id: 4, label: 'option-4', isType: true },
        { id: 3, label: 'option-3', isType: true },
        { id: 5, label: 'option-5', isType: true },
        { id: 7, label: 'option-7', isType: true }
      ],
      valList: [
        { id: 6, label: 'option-6', isType: false },
        { id: 3, label: 'option-3', isType: false },
        { id: 7, label: 'option-7', isType: true }
      ]
    };
  },
  created() {
    this.runInit();
  },
  methods: {
    handleCancel(row = {}) {
      let valList = runClone(this.valList);
      let list = valList.filter(item => item.id !== row.id);

      this.valList = list;
      this.formData.val = list.map(item => item.id);
    },
    changeSelect(e) {
      let options = runClone(this.options);
      let valList = runClone(this.valList);
      let list = [];

      for (let i = 0; i < e.length; i++) {
        let itemA = valList.filter(item => item.id === e[i])[0];
        let itemB = options.filter(item => item.id === e[i])[0];

        itemA ? list.push(itemA) : list.push(itemB);
      }
      list = list.sort((item1, item2) => {
        const a = options.findIndex(item => item.id === item1.id);
        const b = options.findIndex(item => item.id === item2.id);

        return a - b;
      });
      this.valList = runClone(list);
    },
    runInit() {
      this.formData.val = this.valList.map(item => item.id);
    }
  }
};

解析

runClone方法使用JSON.parse(JSON.stringify(val))深度克隆对象或数组。用于确保valList和options不被直接修改。


data()
1、formData.val保存用户在el-select中选择的选项的id。
2、options是可供选择的选项列表,每个选项有id、label和isType(表示“是/否”状态)。
3、valList保存当前已选中的选项及其isType状态。初始值为option-6、option-3和option-7,分别对应不同的isType值。


created生命周期钩子
1、调用runInit()方法,用于初始化formData.val。


handleCancel(row)
1、删除valList中与row.id匹配的选项。
2、更新formData.val使其同步。


changeSelect(e)
1、根据用户选择更新valList。
2、将新选择的选项按顺序添加到valList,并更新其中的isType值。
3、通过sort方法保持valList顺序与options顺序一致。


runInit()
1、初始化formData.val,确保它与valList中的选项一致。

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

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

相关文章

Redis之使用Java代码操作Redis

目录 配置Redis远程访问 安装Redis桌面管理工具 Java操作Redis 创建maven工程 案例演示 连接redis String字符串 Hash哈希 List列表 Set集合 Zset有序集合 配置Redis远程访问 修改访问IP地址 #跳转到redis安装目录 cd /usr/local/redis-6.2.1 #修改redis.con…

SOL项目开发代币DApp的基本要求、模式创建与海外宣发策略

Solana&#xff08;SOL&#xff09;作为一个高性能区块链平台&#xff0c;以其快速的交易速度和低交易成本吸引了大量开发者和投资者。基于Solana开发的去中心化应用程序&#xff08;DApp&#xff09;和代币项目正逐步成为区块链领域的重要组成部分。要成功开发并推广一个SOL项…

通过FHIR和EPIC进行对接

说明 Epic是全美最大电子病历供应商。 FHIR (Fast Health Interoperability Resources)旨在实现医疗健康信息的交换。其中包括了临床数据和健康相关的行政管理数据、公共卫生和临床研究数据。既包括了人类和兽医&#xff0c;又适合大多数应用场景——住院、慢病管理、社区护理…

windows平台的postgresql主从数据库流备份

主: 操作系统:windows10 数据库版本&#xff1a;postgresql-16.2 ip&#xff1a;192.168.3.254 从: 操作系统&#xff1a;windows10 数据库版本&#xff1a;postgresql-16.2 ip&#xff1a;192.168.3.253 配置主库 配置 pg_hba.conf 文件 在 pg 的安装目录下&#xff0c;找到 …

算法_字符串专题---持续更新

文章目录 前言最长公共前缀题目要求题目解析代码如下 最长回文子串题目要求题目解析代码如下 二进制求和题目要求题目解析 字符串相乘题目要求题目解析代码如下 前言 本文将会向你介绍有关字符串的相关题目&#xff1a;最长公共前缀、最长回文子串、二进制求和、字符串相乘。本…

CISAW安全集成和别的类型有什么区别

信息安全人员认证&#xff08;Certified Information Security Assurance Worker, CISAW&#xff09;是由中国网络安全审查技术认证中心依据信息安全领域的不同专业、技术和应用方向以及安全岗位需求&#xff0c;按照ISO/IEC 17024标准建立的多层次认证体系。 CISAW分为三个主…

web前端之选项卡的实现、动态添加类名、动态移除类名、动态添加样式、激活、tabBar

MENU 原生vue 原生 效果图 html 代码 <div class"card"><div class"tab_bar"><div class"item" onclick"handleTabBar(this)">tabBar1</div><div class"item" onclick"handleTabBar(this…

哈佛大学年中回顾2024年ESG发展近况

--- 兼谈新能源企业出海之ESG营销战略 2024年上半年&#xff0c;环境、社会和治理&#xff08;ESG&#xff09;问题以及对方法的不同意见继续成为全球头条新闻。今年年初&#xff0c;公司及其利益相关者在ESG的支持者和批评者之间进行了权衡&#xff0c;虽然近几个月ESG的势头…

cesium添加弹窗,跟随实体移动

先看效果&#xff0c;弹窗会跟随实体移动 1、首先我们先写一个弹窗样式&#xff0c;如果是vue开发&#xff0c;css最好写到公共引入的css &#xff0c;组件内css会编译后会加hash值 2、然后我们 开启 cesium的监听事件&#xff0c; 注意的是 initBubbleWindow方法在地球加载后…

控制阶段在DMAIC中的主要目标是什么?

在探讨DMAIC&#xff08;定义Define、测量Measure、分析Analyze、改进Improve、控制Control&#xff09;这一持续改进流程时&#xff0c;控制阶段作为整个循环的尾声&#xff0c;其重要性不言而喻。控制阶段的主要目标不仅在于巩固前期努力所取得的成果&#xff0c;更在于确保这…

EXCEL 分段排序--Excel难题#86

Excel某表格有3列。 ABC1A1B1512A2B27213A3B33824A4B495A5B5736A6B65777A7B7918A13B131509A14B144910A17B1770211A18B1870512A34B343313A35B3540914A36B3657915A37B3710 现在要求对表格按照第3列进行分段排序&#xff0c;由小到大排列。第1段&#xff1a;第3列小于等于50&…

UE5 datetime 创建日期时间节点 进行加法减法。个人理解

以下均为个人实验和个人理解&#xff0c;仅供参考。 目录 目标节点&#xff1a; 年月日 时分秒毫秒 目标节点&#xff1a; 年月日 年月日以1 为基底。若填的数字<0&#xff0c;该节点会失效。 试验&#xff1a; year基底为1&#xff0c;正常 year基底为0&#xff0c;异…

主流AI绘画工具StableDiffusion最新模型sd3本地部署方法(附工作流)

前言/introduction Stable Diffusion 3&#xff08;简称SD3&#xff09;是Stability AI最新推出的文本到图像生成模型。相比前代模型&#xff0c;SD3在生成质量、细节表现以及运行效率上有了显著提升&#xff0c;尤其在细腻的图像渲染和复杂的场景构建方面表现出色。SD3模型提…

【Harmony OS 4.0】页面路由跳转代码示例

ets/pages/Index.ets import router from ohos.router;Entry Component struct Index {State title: string Index Page;State message: string onPageShow(): void { // 页面每次显示时触发。使用aboutToAppear页面没反应。let record router.getParams() as Record<st…

微服务多个模块启动,端口被占用,yml配置文件读不到

刚刚提交到gitee自己的仓库&#xff0c;拉下来还是报错&#xff0c;然后看到一个解决方法&#xff1a; <build><resources><resource><directory>src/main/java</directory><includes><include>**/*.yml</include><includ…

医院信息管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图详细视频演示技术栈系统测试为什么选择我官方认证玩家&#xff0c;服务很多代码文档&#xff0c;百分百好评&#xff0c;战绩可查&#xff01;&#xff01;入职于互联网大厂&#xff0c;可以交流&#xff0c;共同进步。有保障的售后 代码参考数据库参…

神经重建在自动驾驶模拟中的应用

验证自动驾驶软件需要数百万公里的测试。这不仅意味着系统开发周期长&#xff0c;而且系统的复杂度也会不断增加&#xff0c;同时&#xff0c;大规模的实车测试也会耗费巨量的资源并且可能会面临未知的安全问题。aiSim这样的虚拟仿真工具可以减轻真实世界测试的负担。 AD和ADA…

学习ComfyUI的一个不错网站:www.comflowy.com/basics

学习ComfyUI&#xff0c;不仅仅是照搬别人的工作流来使用&#xff0c;重要的是能自己搭建工作流&#xff0c;而要能够熟练搭建&#xff0c;离不开对工作流中节点&#xff08;特别是重要节点&#xff09;的透彻理解。比如我自己&#xff0c;原来对 Lora 就十分陌生&#xff0c;不…

一款好看的WordPress REST API 主题

介绍&#xff1a; 主题特色&#xff1a; 使用Nuxtjs WordPress Rest Api 实现前后端分离&#xff0c;可完成多端部署&#xff1b; 主题支持自动切换黑夜模式。 使用说明&#xff1a; service 目录为wordpress主题文件&#xff0c;需要拷贝到wordpress主题目录下&#xff0…

创建uni-app项目(vue3+ts+vite)

npx degit dcloudio/uni-preset-vue#vite-ts m-uni-demo1 跳转到对应目录&#xff0c;装包&#xff0c;运行 cd m-uni-demo1 yarn yarn dev:h5 tsconfig.json: {"extends": "vue/tsconfig/tsconfig.json","compilerOptions": {"ignoreDepr…