Можно ли добавить пользовательский атрибут в тег HTML, как показано ниже?
<tag myAttri="myVal" />
Можно ли добавить пользовательский атрибут в тег HTML, как показано ниже?
<tag myAttri="myVal" />
Ответы:
Вы можете изменить свое объявление! DOCTYPE (т. Е. DTD), чтобы разрешить его, чтобы документ [XML] оставался действительным:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
[
<!ATTLIST tag myAttri CDATA #IMPLIED>
]>
#IMPLIED
означает, что это необязательный атрибут, или вы можете использовать #REQUIRED
, и т. д.
Больше информации в DTD - Атрибуты .
<meta http-equiv="content-type" content="application/xhtml+xml" />
.
data-
.
Вы можете добавлять свои атрибуты к своим элементам по желанию. Но это сделает ваш документ недействительным.
В HTML 5 у вас будет возможность использовать пользовательские атрибуты данных с префиксомdata-
.
|
что не допускается в CSS href
, но это то, что необходимо для шрифтов Google
Нет, это нарушит проверку.
В HTML 5 вы можете / сможете добавлять пользовательские атрибуты. Что-то вроде этого:
<tag data-myAttri="myVal" />
Функция jQuery data()
позволяет связывать произвольные данные с элементами DOM. Вот пример .
В HTML5: да: использовать атрибут data .
<ul>
<li data-animal-type="bird">Owl</li>
<li data-animal-type="fish">Salmon</li>
<li data-animal-type="spider">Tarantula</li>
</ul>
Да, вы можете сделать это в самом вопросе <html myAttri="myVal"/>
.
var demo = document.getElementById("demo")
console.log(demo.dataset.myvar)
// or
alert(demo.dataset.myvar)
//this will show in console the value of myvar
<div id="demo" data-myvar="foo">anything</div>
Да, ты можешь сделать это!
Имея следующий HTML
тег:
<tag key="value"/>
Мы можем получить доступ к их атрибутам с помощью JavaScript
:
element.getAttribute('key'); // Getter
element.setAttribute('key', 'value'); // Setter
Element.setAttribute()
поместите атрибут в HTML
тег, если он не существует. Таким образом, вам не нужно объявлять это в HTML
коде, если вы собираетесь установить его с помощью JavaScript
.
key
: может быть любым именем, которое вы хотите использовать для атрибута, но еще не используется для текущего тега.
value
: это всегда строка, содержащая то, что вам нужно.
Вот пример:
document.getElementsByTagName("html").foo="bar"
Вот еще один пример того, как установить пользовательские атрибуты в элемент тега body:
document.getElementsByTagName('body')[0].dataset.attr1 = "foo";
document.getElementsByTagName('body')[0].dataset.attr2 = "bar";
Затем прочитайте атрибут по:
attr1 = document.getElementsByTagName('body')[0].dataset.attr1
attr2 = document.getElementsByTagName('body')[0].dataset.attr2
Вы можете проверить приведенный выше код в консоли в DevTools, например
использовать данные-любые, я использую их много
<aside data-area="asidetop" data-type="responsive" class="top">
data-*
значения из JavaScript?
Другой подход, который является чистым и сохранит документ действительным, заключается в объединении данных, которые вы хотите, в другой тег, например, id, а затем с помощью split, чтобы получить то, что вы хотите, когда вы этого хотите.
<html>
<script>
function demonstrate(){
var x = document.getElementById("example data").querySelectorAll("input");
console.log(x);
for(i=0;i<x.length;i++){
var line_to_illustrate = x[i].id + ":" + document.getElementById ( x[i].id ).value;
//concatenated values
console.log("this is all together: " + line_to_illustrate);
//split values
var split_line_to_illustrate = line_to_illustrate.split(":");
for(j=0;j<split_line_to_illustrate.length;j++){
console.log("item " + j+ " is: " + split_line_to_illustrate[j]);
}
}
}
</script>
<body>
<div id="example data">
<!-- consider the id values representing a 'from-to' relationship -->
<input id="1:2" type="number" name="quantity" min="0" max="9" value="2">
<input id="1:4" type="number" name="quantity" min="0" max="9" value="1">
<input id="3:6" type="number" name="quantity" min="0" max="9" value="5">
</div>
<input type="button" name="" id="?" value="show me" onclick="demonstrate()"/>
</body>
</html>
Вы можете добавить, но затем вы должны написать строку кода JavaScript тоже,
document.createElement('tag');
чтобы убедиться, что все встало на свои места. Я имею в виду Internet Explorer :)
<tag ...>
здесь, по-видимому, означает просто любой тег HTML.
хорошо! вы можете создать кучу пользовательских атрибутов HTML, замаскировав атрибуты данных в соответствии с вашими требованиями.
например.
[attribute='value']{
color:red;
}
<span attribute="value" >hello world</span>
Это, очевидно, работает, но это лишит законной силы ваш документ, вам не нужно использовать JScript для того, чтобы у вас были пользовательские атрибуты или даже элементы, если вам не нужно, вам просто нужно обращаться с новыми сформулированными (пользовательскими) атрибутами точно так же, как вы относитесь к атрибут data
Помните, что «неверный» ничего не значит. Документ будет загружаться нормально все время. и некоторые браузеры фактически проверяют ваш документ только при наличии DOCTYPE ....., вы действительно знаете, что я имею в виду.
Вы можете сделать что-то вроде этого, чтобы извлечь нужное значение из JavaScript вместо атрибута:
<a href='#' class='click'>
<span style='display:none;'>value for JavaScript</span>some text
</a>
<input type="hidden" value="...">
. Примите во внимание разницу между типом данных, которые вы вводите в различные атрибуты, в отличие от данных, которые вы можете поместить в скрытое поле. Сокрытие <span>
(всех вещей) в <a>
целях сохранения части метаданных не является хорошим шагом. Это будет свойственно вашему сайту и очень сильно зависит от JS (изящная деградация, люди).