日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

新建文件夹html文件,JS实现新建文件夹功能

發布時間:2025/4/5 javascript 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 新建文件夹html文件,JS实现新建文件夹功能 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

每天一個JS 小demo之新建文件夾。主要知識點:DOM方法的綜合運用

Document

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;

}

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(){

/* 創建元素,并添加事件 */

var file = document.createElement('div');

var fileName = getFileName();

file.className = "file";

file.innerHTML = ''+fileName+'';

var check = file.querySelector('input[type = "checkbox"]');

var fileName = file.querySelector('.fileName');

file.onmouseover = function(){

this.className = "file fileShow";

};

file.οnmοuseοut= function(){

if(!check.checked){

this.className = "file";

}

};

fileName.onblur = function(){

if(this.innerHTML.trim() == ""){

info.innerHTML = "請輸入文件夾名字";

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 = "文件夾名字重名了,請重新輸入";

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 == "請輸入名字"){

this.innerHTML = "";

}

}

wrap.appendChild(file);

};

del.onclick = function(){

/* 刪除選中的元素 */

var fileName = wrap.querySelectorAll('input:checked+.fileName');

var input = wrap.getElementsByTagName("input")

/* query方法只獲取一次,dom修改了如果不重新獲取,它是不會和dom同步的而get方法會時時和dom同步,dom改了get獲取到的數據也會自定修改 */

//console.log(fileName,input);

for(var i = 0; i < fileName.length; i++){

wrap.removeChild(fileName[i].parentNode);

}

console.log(fileName);

};

// 獲取文件夾名字

/*

創建文件夾名字并進行排序

0 新建文件夾

1 新建文件夾2

2 新建文件夾3

第一種情況:正常排序

*/

function getFileName(){

var fileName = "新建文件夾";

var fileNameLast = "";

var fileNames = wrap.querySelectorAll('.fileName');

if(fileNames.length == 0){ //當前一個都還沒有也就是創建第0個

return fileName;

}

// 當中間可能刪除了幾個

/*

由于中間會刪除再添加,所以順序會被打亂

把所有的名字存入數組,然后進行排序

*/

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)){ /*篩選掉不是已新建文件夾跟隨的不是數字的*/

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);

}

}

//當前順序向后排列 name 就等于在當前的個數上+1

fileNameLast = names.length + 1;

fileName += fileNameLast;

return fileName;

}

};

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持找一找教程網。

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的新建文件夹html文件,JS实现新建文件夹功能的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 我们的2018在线观看免费高清 | 国产制服在线 | 午夜影院网站 | 欧美激情va永久在线播放 | 大尺度舌吻呻吟声 | 亚州av一区二区 | 日韩av综合网站 | 色.com| 国产精品视频久久久久 | 亚洲综合大片69999 | 午夜一级影院 | 黄色成人毛片 | 色多多网站 | 日韩一区二区三区视频 | 色一区二区三区四区 | 亚洲欧美偷拍一区 | 在线麻豆av | 毛片毛片毛片毛片毛片毛片 | 久久免费少妇高潮99精品 | 手机看片日韩欧美 | 性欧美videos高清hd4k | 国产美女av在线 | 少妇无码av无码专区在线观看 | 91黄色片 | 草草在线免费视频 | 美日韩av | 成人国产一区二区三区精品麻豆 | 亚洲精品无码久久久久 | 热久久精品 | 日本视频三区 | 国产色影院 | 夜夜爽夜夜 | 少妇久久久久 | 黄色小网站在线观看 | www.av日韩 | 国产免费自拍 | 人人干天天干 | 玖玖五月 | 黄骗免费网站 | 欧美一卡二卡在线 | 久久免费视频精品 | 亚洲一级片免费看 | 无码精品一区二区三区在线播放 | 国产精品-区区久久久狼 | 少妇性高潮视频 | 国产第九页 | 国产欧美日韩中文字幕 | 国产精品无码自拍 | 国产一级片毛片 | 91在线播放国产 | 国产欧美一区二区三区国产幕精品 | 99国产在线视频 | 久久综合成人 | 国产毛片av | 丰满人妻翻云覆雨呻吟视频 | av色片| 国产乱了高清露脸对白 | 91蜜桃 | 亚洲天堂激情 | 欧美性插视频 | 视频黄页在线观看 | 精品妇女一区二区三区 | 国产综合激情 | 久久中文字幕一区二区 | 久久久久国产一区二区三区潘金莲 | 久久性精品 | 欧洲性开放大片 | 亚洲天堂自拍 | 亚洲欧美视频一区二区 | 日韩精品在线观看视频 | 91视色| 在线看欧美 | 亚洲AV无码一区二区伊人久久 | 日产久久久久久 | 欧美亚洲在线观看 | 亚洲二区中文字幕 | 成人性生交大片免费卡看 | 亚洲av无码一区二区二三区 | 香港三级韩国三级日本三级 | 欧美一区二区三区免费在线观看 | h视频在线免费观看 | 波多一区 | 日韩欧美大陆 | 久久精品成人 | 国产婷婷精品 | 五月天激情视频 | 狠久久| 久久久久久久人妻无码中文字幕爆 | 久久九九综合 | 91精品视频一区二区三区 | 一边摸上面一边摸下面 | 日本久久一区二区 | 久久国产精彩视频 | 人妻少妇精品无码专区二区 | 少妇69xx | 久久色视频 | 久久色中文字幕 | 免费黄色一级 | 蜜臀国产AV天堂久久无码蜜臀 |