排他思想的运用

news2024/9/22 5:44:20

思路简述

  • 需求:桌子上有一排灯,点哪个亮哪个,但是要求每次只能点亮一盏。
  • 如果不使用排他思想,操作过程如下:
    • 第一次打开一盏灯,记为 A,记录下来。
    • 第二次打开灯之前,先去找记录,得知刚才打开的是 A,关掉 A。
    • 第二次打开一盏灯,记为 B,记录下来。
    • 第三次打开灯之前,先去找记录,得知刚才打开的是 B,关掉 B。
    • 上述方法需要频繁操作存储,并且产生了很多变量。
  • 使用排他思想的话,操作过程如下:
    • 第一次打开一盏灯。
    • 第二次打开灯之前,不管之前打开的是谁,让所有的灯都执行关闭操作。
    • 第二次打开一盏灯。
    • 第三次打开灯之前,不管之前打开的是谁,让所有的灯都执行关闭操作。
    • 上述方法未产生新变量,也没有操作存储。

实例应用

  • 低配版 radio 组合
<template>
    <div>
        <div class="redioBlock">
            <div
                class="sinRadio"
                v-for="(item, index) in redioArr"
                :key="index"
                @click="chooseOnlyOne(index)"
            >
                <div class="value" :class="item.value ? 'choosed' : ''"></div>
                <div class="label" :class="item.value ? 'choosed' : ''">
                    {{ item.label }}
                </div>
            </div>
        </div>
    </div>
</template>
<script>
export default {
    data() {
        return {
            redioArr: [
                { value: false, label: "第一个值" },
                { value: false, label: "第二个值" },
                { value: false, label: "第三个值" },
                { value: false, label: "第四个值" },
            ],
        };
    },
    watch: {},
    mounted() {},
    methods: {
        chooseOnlyOne(chooseIndex) {
        	// 遍历灯的数组
            this.redioArr.forEach((item, index) => {
                // 先关掉所有的灯
                item.value = false;
                if (index == chooseIndex) {
                    // 再打开点击的灯
                    item.value = true;
                }
            });
        },
    },
};
</script>
<style lang="less" scoped>
.sinRadio {
    overflow: hidden;
    line-height: 40px;
    .value {
        width: 20px;
        height: 20px;
        float: left;
        border: 1px solid #ccc;
        border-radius: 50%;
        margin-right: 10px;
        margin-top: 10px;
        &.choosed {
            background: #87add8;
            border: 1px solid #87add8;
        }
    }
    .label {
        float: left;
        &.choosed {
            font-weight: bold;
        }
    }
}
</style>

在这里插入图片描述

  • 低配版 radio 组合(利用了 vue 的特性,另一种实现方式,与本文思想无关)
<template>
    <div>
        <div class="redioBlock">
            <div
                class="sinRadio"
                v-for="(item, index) in redioArr"
                :key="index"
                @click="chooseOnlyOne(index)"
            >
                <div
                    class="value"
                    :class="index == activeIndex ? 'choosed' : ''"
                ></div>
                <div
                    class="label"
                    :class="index == activeIndex ? 'choosed' : ''"
                >
                    {{ item.label }}
                </div>
            </div>
        </div>
    </div>
</template>
<script>
export default {
    data() {
        return {
            // 记录当前点击的灯
            activeIndex: null,
            redioArr: [
                { label: "第一个值" },
                { label: "第二个值" },
                { label: "第三个值" },
                { label: "第四个值" },
            ],
        };
    },
    watch: {},
    mounted() {},
    methods: {
        chooseOnlyOne(chooseIndex) {
            this.activeIndex = chooseIndex;
        },
    },
};
</script>
  • 关键信息脱敏(点击星号,只展示当前脱敏信息,其他内容仍是脱敏状态)
<template>
    <div>
        <div class="tableBlock">
            <el-table
                class="myTable"
                :data="tableData"
                style="width: 100%"
                :key="num"
            >
                <el-table-column prop="name" label="姓名" width="200">
                </el-table-column>
                <el-table-column prop="phone" label="电话" width="200">
                    <template slot-scope="scope">
                        <div @click="chooseOnlyOne(scope.$index, 'phone')">
                            {{ scope.row.phoneHidden }}
                        </div>
                    </template>
                </el-table-column>
                <el-table-column prop="idCard" label="证件号">
                    <template slot-scope="scope">
                        <div @click="chooseOnlyOne(scope.$index, 'idCard')">
                            {{ scope.row.idCardHidden }}
                        </div>
                    </template>
                </el-table-column>
            </el-table>
        </div>
    </div>
</template>
<script>
export default {
    data() {
        return {
            // 记录当前点击的灯
            activeIndex: null,
            tableData: [
                {
                    name: "张三",
                    phone: "15222222222",
                    idCard: "100000000000000000",
                },
                {
                    name: "李四",
                    phone: "15222222222",
                    idCard: "100000000000000000",
                },
                {
                    name: "王五",
                    phone: "15222222222",
                    idCard: "100000000000000000",
                },
                {
                    name: "赵六",
                    phone: "15222222222",
                    idCard: "100000000000000000",
                },
            ],
            num: 0,
        };
    },
    watch: {},
    mounted() {
        // 遍历数组,将敏感信息脱敏
        this.tableData.forEach((item, index) => {
            item.phoneHidden = "***";
            item.idCardHidden = "******";
        });
    },
    methods: {
        chooseOnlyOne(chooseIndex, type) {
            // 不管上一次显示明文的是哪个单元格,先将所有的单元格信息脱敏
            this.tableData.forEach((item, index) => {
                item.phoneHidden = "***";
                item.idCardHidden = "******";
            });
            // 获取到当前点击的单元格,让当前点击的单元格显示明文
            this.tableData.forEach((item, index) => {
                if (index == chooseIndex) {
                    if (type == "phone") {
                        // 点击的是手机号,显示手机号明文
                        item.phoneHidden = item.phone;
                    } else {
                        // 点击的是身份证,显示身份证明文
                        item.idCardHidden = item.idCard;
                    }
                }
            });
            // 更新数据后,更新一下表格的节点
            this.num += 1;
        },
    },
};
</script>

在这里插入图片描述

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

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

相关文章

[cpp进阶]C++智能指针

文章目录为什么需要智能指针?智能指针的原理及使用智能指针的原理智能指针的使用C中的智能指针C智能指针的发展历程std::auto_ptrstd::auto_ptr的使用std::auto_ptr的模拟实现std::unique_ptrstd::unique_ptr的使用std::unique_ptr的模拟实现std::shared_ptrstd::shared_ptr的…

Springboot @InitBinder处理from-data表单传参,指定参数默认新增前缀

前言 有兄弟突然找到我&#xff0c;江湖救急&#xff0c;我以为是啥问题呢&#xff1f; 一看这位小兄弟也是半路出家&#xff0c; 没有对springboot的常用注解有过研究。 不过没大碍&#xff0c;还是那句话&#xff0c; 学习的事情&#xff0c;只有先知和后知 现在你看完这篇…

纳米软件分享:光伏逆变器ATE测试系统,逆变器测试解决方案

光伏并网逆变器&#xff08;以下简称“逆变器”&#xff09;是光伏发电系统的核心部件之一&#xff0c;其主要功能是将光伏阵列的直流逆变为符合电网接入要求的交流电并入电网。并网逆变器ATE测试平台&#xff0c;主要是模拟光伏阵列特性输入的直流电源、模拟电网电源、系统控制…

Java垃圾分类查询管理系统源码+数据库,基于SpringBoot+mybatis-plus,垃圾分类查询及预约上门回收

垃圾分类查询管理系统 完整代码下载地址&#xff1a;Java垃圾分类查询管理系统源码数据库 1.介绍 垃圾分类查询管理系统&#xff0c;对不懂的垃圾进行查询进行分类并可以预约上门回收垃圾。 让用户自己分类垃圾&#xff0c; 按国家标准自己分类&#xff0c; 然后在网上提交订…

java学习之main方法

目录 一、main方法的注意事项 二、在IDEA中传入参数 一、main方法的注意事项 形式&#xff1a;public static void main(String[] args){}&#xff0c;main方法是一个静态方法&#xff0c;访问修饰符是&#xff1a;public&#xff0c;形参是String数组 args 注意事项&#xf…

go语言--函数

package mainimport "fmt"func main(){//功能: 10 20var num1 int 10var num2 int 20var sum int 0sum num1sum num2fmt.Println(sum) }为什么使用函数 提高代码的复用性&#xff0c;减少代码冗余, 代码维护性也提高了 函数的定义 为完成摸一个功能的程序指令(…

IRCNN-FPOCS 文章解读

1、论文概述 1&#xff09;待解决的问题&#xff1a;地震道数据缺失&#xff08;野外地震数据的质量往往受到地质环境或设备参数的影响&#xff0c;这些数据可能在空间上不连续&#xff0c;导致地震痕迹缺失&#xff0c;也称为下采样观测&#xff09; 2&#xff09;目的&…

从菜鸟到团队协同大神:产品经理工具技能修炼

现在&#xff0c;自雇人士和自由职业者越来越普遍。受环境影响&#xff0c;员工们正在放弃朝九晚五的工作&#xff0c;转而采用更灵活的远程工作&#xff0c;另一方面&#xff0c;随着办公数字化转型、远程办公的需求强烈、在线协协同管理工具飞项等一批知名互联网工具如雨后春…

c#入门-捕获变量

局部变量捕获 局部函数&#xff0c;匿名函数&#xff0c;可以直接在函数体内使用局部变量。 如果作为委托使用&#xff0c;传递给别人。可能在别人使用委托的时候&#xff0c;这些局部变量的作用域就已经消失了。 因此&#xff0c;编译器会对这些变量做出特殊的操作&#xff…

优维低代码:I18n 国际化

优维低代码技术专栏&#xff0c;是一个全新的、技术为主的专栏&#xff0c;由优维技术委员会成员执笔&#xff0c;基于优维7年低代码技术研发及运维成果&#xff0c;主要介绍低代码相关的技术原理及架构逻辑&#xff0c;目的是给广大运维人提供一个技术交流与学习的平台。 连载…

第8季3:使用字库字符实现区域显示

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、代码框架分析 在第8季2&#xff1a;OSD实验演示与代码分析中&#xff0c;我们分析了SAMPLE_RGN_CreateVideoRegion函数&#xff0c;该函数完成了左下角的logo区域显示、右下角的时间区域显示&a…

Ubuntu18.04安装教程

Ubuntu18.04安装教程# 阿里云源 deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ bionic-updates ma…

【Vue+Springboot】综合程序设计后端部分实现(含跨越访问)

文章目录1、功能展示2、前端部分&#xff1a;VueAPI3、后端部分&#xff1a;Springboot1、功能展示 大致分为用户管理&#xff0c;商品管理&#xff0c;收藏管理&#xff0c;购物车管理&#xff0c;订单管理五个模块。 2、前端部分&#xff1a;VueAPI Vue 使用 axios 库进行网…

如何在Unity中实现MVC模式?

MVC是什么&#xff1f; ​ MVC即Model View Controller&#xff0c;是模型(model)【数据层】&#xff0d;视图(view)【表现层】&#xff0d;控制器(controller)【逻辑层】的缩写。主要应用于网站开发&#xff0c;在游戏开发方面&#xff0c;因为不同游戏的需求、功能不尽相同&…

数字化转型迫在眉睫,企业应该如何面对?

火热的数字化转型&#xff0c;在国企、央企公布数字化转型规划后&#xff0c;进一步向各行各业开始扩散&#xff0c;吸引了很多对于数字化并不熟悉的企业。这些企业大多没有一个确定的目标&#xff0c;只是想要让企业完成转型改革&#xff0c;所以对于怎样做没有什么好的规划。…

Unity3d C#实现基于SocketIOUnity的与后端(node.js为例)Socket通信功能(含工程)

#前言 该功能主要是项目上的需求&#xff0c;按后端的需求就是我们通过SocketIO进行通信&#xff0c;之前游戏通信功能大多是基于原始的Socket进行封装&#xff0c;需要对包体进行设计&#xff0c;还需要粘包拆包等系列操作&#xff0c;属实有点麻烦。这次尝试了SocketIOUnity的…

Exynos_4412——RTC实验

目录 一、ADC小作业 二、RTC简介 三、Exynos_4412下的RTC控制器 四、RTC中的寄存器 五、RTC编程 六、RTC小作业 一、ADC小作业 电压在1501mv~1800mv时&#xff0c;LED2、LED3、LED4、LED5点亮 电压在1001mv~1500mv时&#xff0c;LED2、LED3、LED4点亮 电压在501mv~1000m…

什么是芯片老化测试?芯片老化测试系统NSAT-2000解决方案

随着半导体电子技术的进步&#xff0c;老化测试已成为保证产品质量的关键流程。除了半导体元件外&#xff0c;PCB、IC 和处理器部件也都需要在老化条件下进行测试。本篇文章纳米软件Namisoft小编将带大家分享一下关于芯片老化测试系统的相关知识。 一、什么是芯片老化测试&…

开发工具篇第十二讲:常用开发库 - Lombok工具库详解

开发工具篇第十二讲&#xff1a;常用开发库 - Lombok工具库详解 Lombok是一款非常实用Java工具&#xff0c;可用来帮助开发人员消除Java的冗长代码&#xff0c;尤其是对于简单的Java对象&#xff08;POJO&#xff09;。实际上我并不推荐使用Lombok&#xff08;不主动使用它&…

CANoe测试TC8

OPEN联盟发布的TC8是目前行业内关于车载以太网的标准测试规范之一。 CANoe环境需要硬件和软件: 硬件是CANoe设备&#xff0c;用来连接电脑和DUT&#xff0c;TC8测试的是以太&#xff0c;那么CANoe设备必须支持以太才行&#xff0c;目前VN5640以上都是支持的。 软件需要安装CANo…