利用JavaScript差集實(shí)現(xiàn)一個(gè)對(duì)比小工具
前言
在工作中需要每周統(tǒng)計(jì)人員提交材料情況又不想一個(gè)一個(gè)復(fù)制黏貼查找只好寫一個(gè)小工具幫自己查找誰沒提交材料
先把頁面搞一搞
<!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; } //簡簡單單給按鈕來一個(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) //篩選好的值反饋給頁面的兩個(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ī)的小工具
- 國慶節(jié)到了,利用JS實(shí)現(xiàn)一個(gè)生成國慶風(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-10layui 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-09js+css實(shí)現(xiàn)超簡潔的二級(jí)下拉菜單效果代碼
這篇文章主要介紹了js+css實(shí)現(xiàn)超簡潔的二級(jí)下拉菜單效果代碼,通過非常簡單的JavaScript遍歷頁面元素及動(dòng)態(tài)設(shè)置樣式達(dá)到二級(jí)下拉菜單的效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09