JS實(shí)現(xiàn)新建文件夾功能
更新時(shí)間:2017年06月17日 08:38:31 作者:catEatBird
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)新建文件夾功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
每天一個(gè)JS 小demo之新建文件夾。主要知識(shí)點(diǎn):DOM方法的綜合運(yùn)用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> body { margin: 0; } header { border-bottom: 2px solid #000; height: 40px; line-height: 40px; text-align: center; } .file { margin: 20px; float: left; position: relative; width: 100px; height: 110px; border-radius: 5px; border: 1px solid rgba(0, 0, 0, 0); background: url(img/file.png) no-repeat center 25px; cursor: pointer; } .file input { position: absolute; left: 3px; top: 3px; display: none; } .fileName { position: absolute; left: 5px; bottom: 10px; width: 90px; font: 12px/20px Arial,"宋體"; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .fileShow { border: 1px solid #000; background-color: #f1f1f1; } .fileShow input { display: block; } .info { position: fixed; left: 0; top: 0; width: 100%; height: 50px; font: 30px/50px "宋體"; text-align: center; transform: translateY(-50px); background: #ccc; } </style> <!-- contenteditable 使內(nèi)容可以編輯 --> <script type="text/javascript"> window.onload = function(){ var creat = document.querySelector('.creat'); var del = document.querySelector('.del'); var wrap = document.querySelector('.wrap'); var info = document.querySelector('.info'); var timer = 0; creat.onclick = function(){ /* 創(chuàng)建元素,并添加事件 */ var file = document.createElement('div'); var fileName = getFileName(); file.className = "file"; file.innerHTML = '<input type="checkbox" name=""><span class="fileName" contenteditable>'+fileName+'</span>'; var check = file.querySelector('input[type = "checkbox"]'); var fileName = file.querySelector('.fileName'); file.onmouseover = function(){ this.className = "file fileShow"; }; file.onmouseout= function(){ if(!check.checked){ this.className = "file"; } }; fileName.onblur = function(){ if(this.innerHTML.trim() == ""){ info.innerHTML = "請(qǐng)輸入文件夾名字"; info.style.transform = "translateY(0)"; this.focus(); clearTimeout(timer); timer=setTimeout(function(){ info.style.transform = "translateY(-50px)"; },2000); return; } var fileNames = document.querySelectorAll('.fileName'); for(var i = 0; i < fileNames.length; i++){ if(this != fileNames[i]&&this.innerHTML == fileNames[i].innerHTML){ info.innerHTML = "文件夾名字重名了,請(qǐng)重新輸入"; info.style.transform = "translateY(0)"; this.focus(); clearTimeout(timer); timer=setTimeout(function(){ info.style.transform = "translateY(-50px)"; },2000); } } }; /*onkeydown 鍵盤按下 */ fileName.onkeydown = function(){ if(this.innerHTML == "請(qǐng)輸入名字"){ this.innerHTML = ""; } } wrap.appendChild(file); }; del.onclick = function(){ /* 刪除選中的元素 */ var fileName = wrap.querySelectorAll('input:checked+.fileName'); var input = wrap.getElementsByTagName("input") /* query方法只獲取一次,dom修改了如果不重新獲取,它是不會(huì)和dom同步的而get方法會(huì)時(shí)時(shí)和dom同步,dom改了get獲取到的數(shù)據(jù)也會(huì)自定修改 */ //console.log(fileName,input); for(var i = 0; i < fileName.length; i++){ wrap.removeChild(fileName[i].parentNode); } console.log(fileName); }; // 獲取文件夾名字 /* 創(chuàng)建文件夾名字并進(jìn)行排序 0 新建文件夾 1 新建文件夾2 2 新建文件夾3 第一種情況:正常排序 */ function getFileName(){ var fileName = "新建文件夾"; var fileNameLast = ""; var fileNames = wrap.querySelectorAll('.fileName'); if(fileNames.length == 0){ //當(dāng)前一個(gè)都還沒(méi)有也就是創(chuàng)建第0個(gè) return fileName; } // 當(dāng)中間可能刪除了幾個(gè) /* 由于中間會(huì)刪除再添加,所以順序會(huì)被打亂 把所有的名字存入數(shù)組,然后進(jìn)行排序 */ var names = []; for(var i = 0; i < fileNames.length; i++){ names.push(fileNames[i].innerHTML); } names = names.filter(function(val){ var startName = val.substr(0,5); if(startName != "新建文件夾"){ return false;/*篩選掉不是已新建文件夾命名的*/ } var lastName = val.substr(5); if(isNaN(lastName)){ /*篩選掉不是已新建文件夾跟隨的不是數(shù)字的*/ return false; } return true; }); names.sort(function(a,b){ return a.substr(5) - b.substr(5); }); console.log(names); for(var i = 0; i < names.length; i++){ if(names[0] != fileName){ return fileName; } if(i>0 && names[i] != fileName+(i+1)){ return fileName+(i+1); } } //當(dāng)前順序向后排列 name 就等于在當(dāng)前的個(gè)數(shù)上+1 fileNameLast = names.length + 1; fileName += fileNameLast; return fileName; } }; </script> </head> <body> <div class="info"></div> <header> <input type="button" value="新建文件夾" class="creat" /> <input type="button" value="刪除文件夾" class="del" /> </header> <div class="wrap"> <!-- <div class="file fileShow"> <input type="checkbox" name=""> <span class="fileName">新建文件夾新建文件夾</span> </div> --> </div> </body> </html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
原生JS封裝拖動(dòng)驗(yàn)證滑塊的實(shí)現(xiàn)代碼示例
這篇文章主要介紹了原生JS封裝拖動(dòng)驗(yàn)證滑塊的實(shí)現(xiàn)代碼示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06前端常用6種數(shù)據(jù)加密方式的使用詳細(xì)講解
在前端開(kāi)發(fā)中,常用的數(shù)據(jù)加密技術(shù)包括Base64編碼、MD5哈希、SHA-256哈希、AES對(duì)稱加密、RSA非對(duì)稱加密和HMAC消息認(rèn)證碼,這些加密方式提供了不同層次的數(shù)據(jù)安全保護(hù),適用于不同的安全需求和場(chǎng)景,需要的朋友可以參考下2024-09-09JavaScript對(duì)表格或元素按文本,數(shù)字或日期排序的方法
這篇文章主要介紹了JavaScript對(duì)表格或元素按文本,數(shù)字或日期排序的方法,涉及javascript頁(yè)面元素操作及排序的相關(guān)技巧,需要的朋友可以參考下2015-05-05Layui 數(shù)據(jù)表格批量刪除和多條件搜索的實(shí)例
今天小編就為大家分享一篇Layui 數(shù)據(jù)表格批量刪除和多條件搜索的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09你可能從未使用過(guò)的11+個(gè)JavaScript特性(小結(jié))
這篇文章主要介紹了你可能從未使用過(guò)的11+個(gè)JavaScript特性(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01JS利用Canvas實(shí)現(xiàn)文字水印和圖片水印合成
這篇文章主要為大家詳細(xì)介紹了JavaScript如何利用Canvas實(shí)現(xiàn)文字水印和圖片水印合成的效果,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考一下2022-11-11