ฉันสามารถเพิ่มแอตทริบิวต์ที่กำหนดเองลงในแท็ก 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 Fonts
ไม่จะทำให้การตรวจสอบเกิดความเสียหาย
ใน HTML 5 คุณสามารถ / จะสามารถเพิ่มแอตทริบิวต์ที่กำหนดเองได้ บางสิ่งเช่นนี้
<tag data-myAttri="myVal" />
ใน 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
: เป็นสตริงที่มีสิ่งที่คุณต้องการเสมอ
คุณสามารถตั้งค่าคุณสมบัติจาก JavaScript
document.getElementById("foo").myAttri = "myVal"
นี่คือตัวอย่าง:
document.getElementsByTagName("html").foo="bar"
นี่คือตัวอย่างอีกวิธีการตั้งค่าแอตทริบิวต์ที่กำหนดเองเป็นองค์ประกอบแท็กร่างกาย:
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
คุณสามารถทดสอบโค้ดด้านบนในConsoleใน DevTools เช่น
ใช้ data-any ฉันใช้มันเยอะ
<aside data-area="asidetop" data-type="responsive" class="top">
data-*
ค่าจาก JavaScript ได้อย่างไร
อีกวิธีหนึ่งที่สะอาดและจะรักษาเอกสารให้ถูกต้องคือการเชื่อมข้อมูลที่คุณต้องการในแท็กอื่นเช่น id จากนั้นใช้การแบ่งเพื่อนำสิ่งที่คุณต้องการเมื่อคุณต้องการ
<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>
คุณสามารถเพิ่มได้ แต่คุณต้องเขียนโค้ดจาวาสคริปต์ด้วย
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="...">
เช่นเดียวกับสิ่งที่ชอบ พิจารณาแม้ว่าความแตกต่างระหว่างชนิดของข้อมูลที่คุณใส่ในคุณลักษณะต่าง ๆ โดยเปรียบเทียบกับข้อมูลที่คุณอาจใส่ในฟิลด์ที่ซ่อนอยู่ การซ่อน a <span>
(ของทุกสิ่ง) <a>
เพื่อประโยชน์ในการรักษาส่วนหนึ่งของเมตาดาต้านั้นไม่ใช่เรื่องที่ดี มันจะเป็นเรื่องแปลกสำหรับเว็บไซต์ของคุณและขึ้นอยู่กับ JS เป็นอย่างมาก (ผู้คนที่เสื่อมโทรมอย่างสง่างาม)