本篇文章為大家展示了使用JavaScript怎么動態(tài)添加和刪除類,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
創(chuàng)新互聯(lián)是一家專業(yè)提供久治企業(yè)網站建設,專注與成都網站設計、成都網站建設、H5開發(fā)、小程序制作等業(yè)務。10年已為久治眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網站制作公司優(yōu)惠進行中。首先等到一個 dom 對象(也叫dom元素), 通過document.getElement……的幾種方法得到
如`
let element = document.getElementById("box");
1.通過類名, 獲取類名: el.className, 賦值: el.className = "className" 會覆蓋掉原來的類
2.通過屬性,獲取類名: el.getAttribute("class"); 賦值: el.setAttribute("class", "className1 className2"); 會覆蓋掉原來的類
3.通過屬性節(jié)點 attributeNode(性能差一點,但能兼容ie,getAttribute() ie 的有些版本不支持 )setAttributeNode() 方法向元素中添加指定的屬性節(jié)點。
如果這個指定的屬性已存在,則此方法會替換它。,獲取類名: getAttributeNode("class").value, 賦值:
let attr = document.createAttribute("class"); attr.nodeValue = "className"; el.setAttributeNode(attr)
4.通過 classList屬性, 獲取類名 el.classList; 追加類名: el.classList.add("className"); 刪除類 : el.calssList.remove("className");
上邊四種方法, classList最靈活,最好好用, 但是不支持 ie9 以下的瀏覽器, 兼容性要差一些
代碼如下:
html
<div id="btn-group"> <div class="btn btn-active">按鈕1</div> <div class="btn">按鈕2</div> <div class="btn">按鈕3</div> <div class="btn">按鈕4</div> </div>
js代碼, 其中用到了ES6語法(用ES6寫簡潔)
let myEventUtil = { // 添加監(jiān)聽事件 addEvent (element, type, handler) { if (element.addEventListener) { element.addEventListener(type, handler, false); } else if (element.attach){ // ie element.attach("on"+ type, handler); } else { element['on' + type] = handler; } }, getTarget (event) { let event = event || window.event; return event.target || event.srcElement; } } let my$ = id => document.getElementById(id); let btnGroup = my$(“btn-group”); myEventUtil.addEvent(btnGroup, 'on', function (ev) { // 給所有的 btn 都移除激活的類 btn-active // console.log(this) ==> 是一個dom元素 btnGroup // 可以通過 el.children[i]拿到具體的子元素 // 拿到子元素了可以通過 el.classList.remove("className") 刪除類 // el.classList.add("className") 來添加類 // 刪除類 let len = this.children.length; for (let i = 0; i < len; i ++) { this.children[i].classList.remove("btn-active"); // this.children[i].className = "btn"; // 用其中一個就行 } // 添加類, 拿到具體的 btn 給它添加類 myEventUtil.getTarget(ev).classList.add("btn-active"); // myEventUtil.getTarget(ev).className = "btn"; // 用其中一個就行 });
1、js屬于一種解釋性腳本語言;2、在絕大多數(shù)瀏覽器的支持下,js可以在多種平臺下運行,擁有著跨平臺特性;3、js屬于一種弱類型腳本語言,對使用的數(shù)據(jù)類型未做出嚴格的要求,能夠進行類型轉換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實現(xiàn)信息瀏覽或動態(tài)交互,從而有效地防止數(shù)據(jù)的丟失;5、基于對象的腳本語言,js不僅可以創(chuàng)建對象,也能使用現(xiàn)有的對象。
上述內容就是使用JavaScript怎么動態(tài)添加和刪除類,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)成都網站設計公司行業(yè)資訊頻道。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
分享文章:使用JavaScript怎么動態(tài)添加和刪除類-創(chuàng)新互聯(lián)
網頁地址:http://jinyejixie.com/article26/cceecg.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、云服務器、服務器托管、動態(tài)網站、電子商務、網站導航
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容