利用JavaScript差集實(shí)現(xiàn)一個(gè)對(duì)比小工具
前言
在工作中需要每周統(tǒng)計(jì)人員提交材料情況又不想一個(gè)一個(gè)復(fù)制黏貼查找只好寫一個(gè)小工具幫自己查找誰(shuí)沒(méi)提交材料
先把頁(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)丑,無(wú)所謂了自己用
開始寫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)單單給按鈕來(lái)一個(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ò)程
相關(guān)文章
javascript獲取dom的下一個(gè)節(jié)點(diǎn)方法
這篇文章主要介紹了javascript獲取dom的下一個(gè)節(jié)點(diǎn)方法,實(shí)現(xiàn)在頁(yè)面點(diǎn)擊加減按鈕數(shù)字的累加,需要的朋友可以參考下2014-09-09
JavaScript通過(guò)prototype給對(duì)象定義屬性用法實(shí)例
這篇文章主要介紹了JavaScript通過(guò)prototype給對(duì)象定義屬性用法,實(shí)例分析了prototype的功能及使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
使用javascript做的一個(gè)隨機(jī)點(diǎn)名程序
這篇文章主要介紹了使用javascript做的一個(gè)隨機(jī)點(diǎn)名程序,經(jīng)測(cè)試,效果相當(dāng)不錯(cuò),需要的朋友可以參考下2014-02-02
JS Generator函數(shù)yield表達(dá)式示例詳解
這篇文章主要為大家介紹了JS Generator函數(shù)yield表達(dá)式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
JS實(shí)現(xiàn)簡(jiǎn)單的文字無(wú)縫上下滾動(dòng)功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)簡(jiǎn)單的文字無(wú)縫上下滾動(dòng)功能,結(jié)合實(shí)例形式分析了JavaScript結(jié)合時(shí)間函數(shù)動(dòng)態(tài)操作頁(yè)面元素屬性變換實(shí)現(xiàn)文字滾動(dòng)功能相關(guān)操作技巧,需要的朋友可以參考下2019-06-06
js網(wǎng)頁(yè)中的(運(yùn)行代碼)功能實(shí)現(xiàn)思路
網(wǎng)頁(yè)中的"運(yùn)行代碼"是一個(gè)很方便的功能,可以直接看到代碼的效果,感興趣的朋友不妨參考下,或許對(duì)你學(xué)習(xí)js有所幫助,好了花不多說(shuō)切入正題2013-02-02

