javascript 数据分析(利用JavaScript差集实现一个对比小工具)
类别:编程学习 浏览量:651
时间:2021-11-04 19:26:11 javascript 数据分析
利用JavaScript差集实现一个对比小工具前言
在工作中需要每周统计人员提交材料情况又不想一个一个复制黏贴查找只好写一个小工具帮自己查找谁没提交材料
先把页面搞一搞
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> textarea { /* border: none; */ width: 49%; height: 400px; /* font-size: 17pt; */ } #btn { width: 100%; height: 50px; position: relative; top: 0px; /* position: absolute; */ } #p2 { margin-left: 940px; margin-top: -38px; } </style> </head> <body> <button id="btn" class="ambi-light-button">对比</button> <textarea id="txt" type="text" placeholder="应提交"></textarea> <textarea id="txt2" type="text" placeholder="已提交"></textarea> <hr> <p>未提交</p> <p id="p2">已提交未在人名单</p> <textarea id="txt3" type="text" placeholder="未提交"></textarea> <textarea id="txt4" type="text" placeholder="已提交未在人名单"></textarea> </body> </html>
有点丑,无所谓了自己用
开始写JS代码
<script //先把输入框,按钮获取一下 let txt = document.querySelector('#txt') let txt2 = document.querySelector('#txt2') let txt3 = document.querySelector('#txt3') let txt4 = document.querySelector('#txt4') let btn = document.querySelector('#btn') //然后写一个数组去重求差集 const getDifference = function (a, b) { //解释:如果传入的两个函数是数组 if (a.constructor === Array && b.constructor === Array) { let set1 = new Set(a); let set2 = new Set(b); // 利用Set去重,筛选找到差值 return Array.from(new Set([...set1].filter(x => !set2.has(x)))); } return null; } //简简单单给按钮来一个点击事件吧 btn.onclick = function () { //应提交人名单 let Should_sub = txt.value.split('\n') //未提交人名单 let already_sub = txt2.value.split('\n') let l3 = getDifference(Should_sub, already_sub) //未在人名单中提交人数 let l4 = getDifference(already_sub, Should_sub) //筛选好的值反馈给页面的两个输入框 txt3.value = l3.join('\n') txt4.value = l4.join('\n') } </script>
总结
到此这篇关于利用JavaScript差集实现一个对比小工具的文章就介绍到这了,更多相关JS差集实现对比小工具内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- jscanvas画折线图(js+canvas实现代码雨效果)
- python将对象转换成json(python对象与json相互转换的方法)
- python class转json(Python对象转换为json的方法步骤)
- JS实现金额大小写转换
- Js操作cookie
- extjs中treegrid
- javascript写游戏脚本(原生JS实现飞机大战小游戏)
- js和css哪个重要(js与css的阻塞问题详析)
- js简单小游戏代码(用JS实现飞机大战小游戏)
- js函数声明和函数表达式的区别
- vue多个对象实现双向数据绑定(利用js实现Vue2.0中数据的双向绑定功能)
- 什么是jsonp格式
- js移动端菜上下滑动效果(JS实现移动端上下滑动一次一屏)
- extjs tabPanel的用法
- js实时获取页面宽度(JavaScript获取网页的宽高及如何兼容详解)
- MVC JsonResult的用法
- 高马尾扎发(高马尾扎发教程视频)
- 这里输入关键词(请手动输入关键词)
- 小说 顾瑾岚拿出一套飞行棋,别说你连飞行棋都不会哦(顾瑾岚拿出一套飞行棋)
- 金品公司 界界乐中秋限定飞行棋礼盒 露营藤篮礼盒全新上市(界界乐中秋限定飞行棋礼盒)
- 必看 8月,相比七夕,更需要注意的是这些事(必看8月相比七夕)
- 8月23日11时16分将迎处暑,逐渐进入气象意义上的秋天(8月23日11时16分将迎处暑)
热门推荐
- thinkphp继承model如何使用(Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作详解)
- SQL中的注释
- mysql8.0详解(MySQL 8.0 的 5 个新特性,太实用了!)
- mac的mysql连接问题如何解决(MAC 中mysql密码忘记解决办法)
- docker常用操作(docker常用命令汇总)
- php实现非递归快速排序(PHP实现无限极分类的两种方式示例递归和引用方式)
- 面试时问期望工资怎么回答
- EasyUI DateBox设置默认值
- phpredis高级用法(PHP Redis扩展无法加载的问题解决方法)
- django中的urlpatterns(Django web框架使用url path name详解)