您好,登錄后才能下訂單哦!
怎么在JavaScript中利用removeAttribute()方法刪除元素的屬性?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
在 JavaScript 中,使用元素的 removeAttribute() 方法可以刪除指定的屬性。用法如下:
removeAttribute(name)
參數(shù) name 表示元素的屬性名。
下面示例演示了如何動(dòng)態(tài)設(shè)置表格的邊框。
<script> window.onload = function () { //綁定頁(yè)面加載完畢時(shí)的事件處理函數(shù) var table = document.getElementByTagName("table")[0]; //獲取表格外框的引用 var del = document.getElementById("del"); var reset = document.getElementById("reset"); del.onclick = function () { table.removeAttribute("border"); } reset.onclick = function () { table.setAttribute("border", "2"); } </script> <table width="100%" border="2"> <tr> <td>數(shù)據(jù)表格</td> <tr> </table> <button id="del">刪除</button><button id="reset">恢復(fù)</button>
在上面示例中設(shè)計(jì)了兩個(gè)按鈕,并分別綁定了不同的事件處理函數(shù)。單擊“刪除”按鈕即可調(diào)用表格的 removeAttribute() 方法清除表格邊框,單擊“恢復(fù)”按鈕即可調(diào)用表格的 setAttribute() 方法重新設(shè)置表哥便可的粗細(xì)。
下面示例演示了如何自定義刪除類函數(shù),并調(diào)用該函數(shù)刪除指定類名。
<script> function hasClass (element, className) { //類名檢測(cè)函數(shù) var reg = new RegExp ('(\\s|^)' + className + '(\\s|$)'); return reg.test (element, className); //使用正則檢測(cè)是否有相同的樣式 } function deleteClass (element, className) { if (hasClass (element, className)) { element.className.replace (reg, ' '); //捕獲要?jiǎng)h除樣式,然后替換為空白字符串 } } </script> <div id="red" class="red blue bold">盒子</div> <script> var red = document.getElementById ("red"); deleteClass (red, 'blue'); </script>
上面代碼使用正則表達(dá)式檢測(cè) className 屬性值字符串中是否包含指定的類名,如果存在,則使用空字符串替換掉匹配到的子字符串,從而實(shí)現(xiàn)刪除類名的目的。
removeAttribute
移除節(jié)點(diǎn)指定名稱的屬性。示例如下
document.getElementById('riskTypePie').removeAttribute("style");
removeAttributeNode
注:此方法不兼容IE。
使用方法:
獲取要?jiǎng)h除屬性的元素
獲取該元素要?jiǎng)h除的屬性
<元素>.removeAttributeNode<屬性>
var node=document.getElementById('chartWrap'); var attr=n.getAttributeNode('style'); node.removeAttributeNode(attr);
異同分析
相同點(diǎn)
兩個(gè)方法都是用來(lái)移除節(jié)點(diǎn)屬性
兩種方法調(diào)用者都只能是標(biāo)簽節(jié)點(diǎn)
不同點(diǎn)
removeAttribute方法接收的是要?jiǎng)h除屬性的名字
removeAttributeNode方法接收的是要?jiǎng)h除的屬性節(jié)點(diǎn)它本身
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。