Posso adicionar um atributo personalizado a uma tag HTML como a seguir?
<tag myAttri="myVal" />
Posso adicionar um atributo personalizado a uma tag HTML como a seguir?
<tag myAttri="myVal" />
Respostas:
Você pode alterar sua declaração! DOCTYPE (ou seja, DTD) para permitir isso, para que o documento [XML] ainda seja válido:
<!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
significa que é um atributo opcional ou você pode usar #REQUIRED
etc.
Mais informações estão em DTD - Atributos .
<meta http-equiv="content-type" content="application/xhtml+xml" />
.
data-
.
Você pode adicionar atributos personalizados aos seus elementos à vontade. Mas isso tornará seu documento inválido.
No HTML 5, você terá a oportunidade de usar atributos de dados personalizados com o prefixodata-
.
|
não é permitido em um css href
, mas isso é o que é necessário para o Google Fonts
Não, isso interromperá a validação.
No HTML 5, você pode / poderá adicionar atributos personalizados. Algo assim:
<tag data-myAttri="myVal" />
A data()
função jQuery permite associar dados arbitrários a elementos DOM. Aqui está um exemplo .
No HTML5: yes: use o atributo de dados .
<ul>
<li data-animal-type="bird">Owl</li>
<li data-animal-type="fish">Salmon</li>
<li data-animal-type="spider">Tarantula</li>
</ul>
Sim, você pode, você fez isso na própria questão: <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>
Sim, você consegue!
Tendo a próxima HTML
tag:
<tag key="value"/>
Podemos acessar seus atributos com JavaScript
:
element.getAttribute('key'); // Getter
element.setAttribute('key', 'value'); // Setter
Element.setAttribute()
coloque o atributo na HTML
tag, se não existir. Portanto, você não precisa declará-lo no HTML
código se quiser configurá-lo JavaScript
.
key
: pode ser qualquer nome que você deseja para o atributo, enquanto ainda não estiver sendo usado para a tag atual.
value
: é sempre uma string contendo o que você precisa.
Aqui está o exemplo:
document.getElementsByTagName("html").foo="bar"
Aqui está outro exemplo de como definir atributos personalizados no elemento de tag do corpo:
document.getElementsByTagName('body')[0].dataset.attr1 = "foo";
document.getElementsByTagName('body')[0].dataset.attr2 = "bar";
Em seguida, leia o atributo:
attr1 = document.getElementsByTagName('body')[0].dataset.attr1
attr2 = document.getElementsByTagName('body')[0].dataset.attr2
Você pode testar o código acima no Console do DevTools, por exemplo
usar dados - qualquer, eu os uso bastante
<aside data-area="asidetop" data-type="responsive" class="top">
data-*
valores do JavaScript?
Outra abordagem, que é limpa e manterá o documento válido, é concatenar os dados que você deseja em outra tag, por exemplo, id, e usar split para obter o que você deseja quando quiser.
<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>
Você pode adicionar, mas também precisa escrever uma linha de código JavaScript,
document.createElement('tag');
para garantir que tudo caia no lugar. Quero dizer Internet Explorer :)
<tag ...>
aqui significa aparentemente qualquer tag HTML.
bem! você pode criar vários atributos HTML personalizados, disfarçando os atributos de dados do que você realmente deseja.
por exemplo.
[attribute='value']{
color:red;
}
<span attribute="value" >hello world</span>
Aparentemente, ele funciona, mas isso invalidaria seu documento. Não há necessidade de usar o JScript para que você tenha atributos personalizados ou até elementos, a menos que precise, basta tratar seus novos atributos formulados (personalizados) da mesma maneira que você trata seus documentos. atributo "data"
Lembre-se de "inválido" não significa nada. O documento carrega bem o tempo todo. e alguns navegadores realmente validariam seu documento apenas pela presença de DOCTYPE ....., você realmente entende o que quero dizer.
Você pode fazer algo assim para extrair o valor desejado do JavaScript, em vez de um atributo:
<a href='#' class='click'>
<span style='display:none;'>value for JavaScript</span>some text
</a>
<input type="hidden" value="...">
. Considere, no entanto, a diferença entre o tipo de dados que você coloca em vários atributos, em contraste com os dados que você pode colocar em um campo oculto. Ocultar um <span>
(de todas as coisas) de forma <a>
a manter um pedaço de metadados não é uma boa jogada. Seria peculiar ao seu site e muito dependente do JS (degradação graciosa, pessoal).