利用JavaScript差集實(shí)現(xiàn)一個(gè)對(duì)比小工具
前言
在工作中需要每周統(tǒng)計(jì)人員提交材料情況又不想一個(gè)一個(gè)復(fù)制黏貼查找只好寫一個(gè)小工具幫自己查找誰沒提交材料
先把頁(yè)面搞一搞
<!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">對(duì)比</button>
<textarea id="txt" type="text" placeholder="應(yīng)提交"></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>

有點(diǎn)丑,無所謂了自己用
開始寫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')
//然后寫一個(gè)數(shù)組去重求差集
const getDifference = function (a, b) {
//解釋:如果傳入的兩個(gè)函數(shù)是數(shù)組
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;
}
//簡(jiǎn)簡(jiǎn)單單給按鈕來一個(gè)點(diǎn)擊事件吧
btn.onclick = function () {
//應(yīng)提交人名單
let Should_sub = txt.value.split('\n')
//未提交人名單
let already_sub = txt2.value.split('\n')
let l3 = getDifference(Should_sub, already_sub)
//未在人名單中提交人數(shù)
let l4 = getDifference(already_sub, Should_sub)
//篩選好的值反饋給頁(yè)面的兩個(gè)輸入框
txt3.value = l3.join('\n')
txt4.value = l4.join('\n')
}
</script>
總結(jié)
到此這篇關(guān)于利用JavaScript差集實(shí)現(xiàn)一個(gè)對(duì)比小工具的文章就介紹到這了,更多相關(guān)JS差集實(shí)現(xiàn)對(duì)比小工具內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 如何利用node.js開發(fā)一個(gè)生成逐幀動(dòng)畫的小工具
- Node.js 實(shí)現(xiàn)搶票小工具 & 短信通知提醒功能
- java9的JShell小工具和編譯器兩種自動(dòng)優(yōu)化方法
- Node.js實(shí)現(xiàn)JS文件合并小工具
- javascript制作sql轉(zhuǎn)換為stringBuffer的小工具
- js 創(chuàng)建書簽小工具之理論
- 用hta[javascript]寫的定時(shí)重啟或關(guān)機(jī)的小工具
- 國(guó)慶節(jié)到了,利用JS實(shí)現(xiàn)一個(gè)生成國(guó)慶風(fēng)頭像的小工具 詳解實(shí)現(xiàn)過程
相關(guān)文章
微信JS-SDK updateAppMessageShareData安卓不能自定義分享詳解
這篇文章主要介紹了微信JS-SDK updateAppMessageShareData安卓不能自定義分享詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
小程序?qū)崿F(xiàn)左滑刪除的效果的實(shí)例代碼
這篇文章主要介紹了小程序?qū)崿F(xiàn)左滑刪除的效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
layui switch 開關(guān)監(jiān)聽 彈出確定狀態(tài)轉(zhuǎn)換的例子
今天小編就為大家分享一篇layui switch 開關(guān)監(jiān)聽 彈出確定狀態(tài)轉(zhuǎn)換的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09
動(dòng)態(tài)JavaScript所造成一些你不知道的危害
這篇文章給大家整理了動(dòng)態(tài)JavaScript所造成的一些大家可能不知道的危害,文章介紹的很詳細(xì),有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-09-09
js+css實(shí)現(xiàn)超簡(jiǎn)潔的二級(jí)下拉菜單效果代碼
這篇文章主要介紹了js+css實(shí)現(xiàn)超簡(jiǎn)潔的二級(jí)下拉菜單效果代碼,通過非常簡(jiǎn)單的JavaScript遍歷頁(yè)面元素及動(dòng)態(tài)設(shè)置樣式達(dá)到二級(jí)下拉菜單的效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09

