詳解JavaScript添加給定的標簽選項
更新時間:2018年09月17日 08:26:33 投稿:laozhang
這篇文章給大家分享了JavaScript實現(xiàn)添加給定的標簽選項的相關知識點內容以及代碼實例,有興趣的朋友們參考下。
先看看效果圖:

代碼實現(xiàn):
HTML代碼:
<h3>haveTags</h3> <div id="havetags"></div> <hr /> <h3>addTags</h3> <div id="addtags"></div> <button id="btn">返回的數(shù)組</button>
css代碼:
#havetags span,
#addtags span {
display: inline-block;
padding: 0 0 0 10px;
margin: 2px 5px;
border: 1px solid #000;
}
#havetags span::after,
#addtags span::after {
content: "+";
display: inline-block;
padding: 0 10px;
background-color: #00ffff;
margin-left: 5px;
}
#addtags span::after {
content: "x";
}
js代碼:
// 擁有的標簽
var haveArr = ["HTML", "CSS", "JavaScript", "jQuery", "Vue", "Bootstrap"];
// 添加的標簽
var addArr = ["PHP", "MySQL"];
/**
* [tagsShow 展示擁有的標簽]
* @param {[String]} haveTagsId [展示擁有標簽的HTML標簽Id]
* @param {[String]} addTagsId [展示添加標簽的HTML標簽Id]
* @param {[Array]} haveTags [擁有標簽的數(shù)組]
* @param {[Array]} addTags [添加標簽的數(shù)組]
*/
function tagsShow(haveTagsId, addTagsId, haveTags, addTags) {
for(var i = 0; i < haveTags.length; i++) {
document.getElementById(haveTagsId).innerHTML += "<span>" + haveTags[i] + "</span>";
}
addTag(haveTagsId, addTagsId, haveArr, addArr);
for(var i = 0; i < addTags.length; i++) {
document.getElementById(addTagsId).innerHTML += "<span>" + addTags[i] + "</span>";
}
delTag(haveTagsId, addTagsId, haveTags, addTags);
}
/**
* 添加標簽
* @param {[String]} haveTagsId [展示擁有標簽的HTML標簽Id]
* @param {[String]} addTagsId [展示添加標簽的HTML標簽Id]
* @param {[Array]} haveTags [擁有標簽的數(shù)組]
* @param {[Array]} addTags [添加標簽的數(shù)組]
*/
function addTag(haveTagsId, addTagsId, haveTags, addTags) {
var len = document.getElementById(haveTagsId).children.length;
for(var i = 0; i < len; i++) {
document.getElementById(haveTagsId).children[i].onclick = function() {
this.remove();
addTags.push(this.innerHTML);
document.getElementById(addTagsId).innerHTML += "<span>" + this.innerHTML + "</span>";
haveTags.splice(haveTags.indexOf(this.innerHTML), 1); // 從數(shù)組中刪除該元素
delTag(haveTagsId, addTagsId, haveTags, addTags);
}
}
}
/**
* 刪除標簽
* @param {[String]} haveTagsId [展示擁有標簽的HTML標簽Id]
* @param {[String]} addTagsId [展示添加標簽的HTML標簽Id]
* @param {[Array]} haveTags [擁有標簽的數(shù)組]
* @param {[Array]} addTags [添加標簽的數(shù)組]
*/
function delTag(haveTagsId, addTagsId, haveTags, addTags) {
var len = document.getElementById(addTagsId).children.length;
for(var i = 0; i < len; i++) {
document.getElementById(addTagsId).children[i].onclick = function() {
this.remove();
haveTags.push(this.innerHTML);
document.getElementById(haveTagsId).innerHTML += "<span>" + this.innerHTML + "</span>";
addTags.splice(addTags.indexOf(this.innerHTML), 1); // 從數(shù)組中刪除該元素
addTag(haveTagsId, addTagsId, haveTags, addTags);
}
}
}
// 展示標簽
tagsShow('havetags', 'addtags', haveArr, addArr);
// 最終數(shù)組
document.getElementById("btn").onclick = function() {
console.log(haveArr);
console.log(addArr);
}
以上就是JavaScript如何實現(xiàn)添加給定的標簽選項?(代碼實例)的詳細內容,更多請關注php中文網其它相關文章!
相關文章
JavaScript實現(xiàn)Java中Map容器的方法
這篇文章主要介紹了JavaScript實現(xiàn)Java中Map容器的方法,結合實例形式分析了JavaScript實現(xiàn)Java中Map容器的原理與相關實現(xiàn)技巧,需要的朋友可以參考下2016-10-10
為JS擴展Array.prototype.indexOf引發(fā)的問題探討及解決
Array沒有indexOf方法,這樣在一個數(shù)組中查找某個元素的索引時比較麻煩,于是通過prototype原型擴展了Array.prototype.indexOf(),在對數(shù)組進行遍歷的時候卻出現(xiàn)了問題2013-04-04
DOM操作原生js 的bug,使用jQuery 可以消除的解決方法
下面小編就為大家?guī)硪黄狣OM操作原生js 的bug,使用jQuery 可以消除的解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09
html的DOM中document對象anchors集合用法實例
這篇文章主要介紹了html的DOM中document對象anchors集合用法,實例分析了anchors集合的功能及使用技巧,需要的朋友可以參考下2015-01-01
JavaScript實現(xiàn)設計模式中的單例模式的一些技巧總結
單例模式是JavaScript項目中最常用的設計模式之一,下面羅列了JavaScript實現(xiàn)設計模式中的單例模式的一些技巧總結,包括惰性加載與分支技術等,需要的朋友可以參考下.2016-05-05

