Home >Web Front-end >JS Tutorial >How to use setAttribute in JavaScript

How to use setAttribute in JavaScript

高洛峰
高洛峰Original
2016-11-25 11:51:151796browse

We often need to dynamically add various attributes to Element in JavaScript. This can be achieved by using setAttribute(), which involves browser compatibility issues.

setAttribute(string name, string value): Add a new attribute with a specified name and value, or set an existing attribute to a specified value.

1. Style issues

In setAttribute("class", value), class refers to changing the attribute "class", so it must be in quotes.

vName represents assigning a value to the style.

For example:

var input = document.createElement("input");

input.setAttribute("type", "text");

input.setAttribute("name", "q");

input.setAttribute("class",bordercss);

When outputting: , that is, the input control has bordercss style attributes

Note: class Properties play an important role in the W3C DOM, but still exist due to browser differences.

Using the setAttribute("class", vName) statement to dynamically set the class attribute of Element works in Firefox, but not in IE. Because the browser using the IE core does not recognize "class", it must use "className" instead;

Similarly, firefox does not recognize "className" either. So the commonly used method is to use both:

element.setAttribute("class", value); //for firefox

element.setAttribute("className", value); //for IE

2. Method Issues such as attributes

For example:

var bar = document.getElementById("testbt");

bar.setAttribute("onclick", "javascript:alert('This is a test!');");

Here, setAttribute is used to specify the onclick attribute of e, which is simple and easy to understand.

But IE does not support it. It is not that IE does not support the setAttribute function, but it does not support using setAttribute to set certain attributes, such as object attributes, collection attributes, and event attributes. In other words, using setAttribute to set style and onclick attributes does not work in IE. It won't work.

In order to achieve compatibility with various browsers, you can use the dot notation method to set the object properties, collection properties and event properties of Element.

document.getElementById("testbt").className = "bordercss";

document.getElementById("testbt").style.cssText = "color: #00f;";

document.getElementById("testbt") .style.color = "#00f";

document.getElementById("testbt").onclick= function () { alert("This is a test!"); }



Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn