Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 <!DOCTYPE html> | |
| 2 <meta charset="utf-8"> | |
| 3 <title>Ensure NodeList semantically matches WebIDL iterable/title> | |
| 4 <script src="../../../resources/testharness.js"></script> | |
| 5 <script src="../../../resources/testharnessreport.js"></script> | |
| 6 <div id="container"> | |
| 7 <div id="div1"></div> | |
| 8 <div id="div2"></div><br> | |
| 9 <div id="div3"></div><br> | |
| 10 <div id="div4"></div><br> | |
| 11 <div id="div5"></div><br> | |
| 12 <form id="form"> | |
| 13 <input id="rad1" type="radio" name="radio" value="a"> | |
| 14 <input id="rad2" type="radio" name="radio" value="b"> | |
| 15 <input id="rad3" type="radio" name="radio" value="c"> | |
| 16 <input id="rad4" type="radio" name="radio" value="d"> | |
| 17 </form> | |
| 18 </div> | |
| 19 <script> | |
| 20 "use strict"; | |
| 21 | |
| 22 test(function () { | |
| 23 let nodeList = container.querySelectorAll("div"); | |
| 24 let id = 0; | |
| 25 for (let node of nodeList) { | |
| 26 assert_true(node instanceof HTMLDivElement, "elements should be expected types"); | |
| 27 assert_equals(node.id, "div" + ++id, "elements should be the expected va lues"); | |
| 28 } | |
| 29 }, "for (node of NodeList)"); | |
| 30 | |
| 31 | |
| 32 test(function () { | |
| 33 let nodeList = container.querySelectorAll("div"); | |
| 34 for (let entry of nodeList.entries()) { | |
| 35 let id = entry[0] + 1; | |
| 36 let node = entry[1]; | |
| 37 assert_true(node instanceof HTMLDivElement, "elements should be expected types"); | |
| 38 assert_equals(node.id, "div" + id, "elements should be the expected valu es"); | |
| 39 } | |
| 40 }, "for ([index, node] of NodeList.entries())"); | |
| 41 | |
| 42 | |
| 43 test(function () { | |
| 44 let nodeList = container.querySelectorAll("div"); | |
| 45 for (let id of nodeList.keys()) { | |
| 46 let node = nodeList[id++]; | |
| 47 assert_true(node instanceof HTMLDivElement, "elements should be expected types"); | |
| 48 assert_equals(node.id, "div" + id, "elements should be the expected valu es"); | |
| 49 } | |
| 50 }, "for (index of NodeList.keys())"); | |
| 51 | |
| 52 | |
| 53 test(function () { | |
| 54 let nodeList = container.querySelectorAll("div"); | |
| 55 let id = 0; | |
| 56 for (let node of nodeList.values()) { | |
| 57 assert_true(node instanceof HTMLDivElement, "elements should be expected types"); | |
| 58 assert_equals(node.id, "div" + ++id, "elements should be the expected va lues"); | |
| 59 } | |
| 60 }, "for (node of NodeList.values())"); | |
| 61 | |
| 62 | |
| 63 test(function () { | |
| 64 let nodeList = container.querySelectorAll("div"); | |
| 65 nodeList.forEach(function(node, id) { | |
| 66 assert_true(node instanceof HTMLDivElement, "elements should be expected types"); | |
| 67 assert_equals(node.id, "div" + ++id, "elements should be the expected va lues"); | |
| 68 }); | |
| 69 }, "iterable<Node>#forEach()"); | |
| 70 | |
| 71 | |
| 72 test(function() { | |
| 73 let nodeList = form.radio; | |
| 74 let rad = rad1; | |
| 75 let id = 0; | |
| 76 for (let node of nodeList) { | |
| 77 assert_true(node instanceof HTMLInputElement, "elements should be expect ed types"); | |
| 78 assert_equals(node.id, "rad" + ++id, "elements should be the expected va lues"); | |
| 79 if (node === rad2) { | |
| 80 rad1.remove(); | |
| 81 ++id; | |
| 82 assert_equals(nodeList[0], rad2); | |
| 83 } | |
| 84 } | |
| 85 form.insertBefore(rad, rad2); | |
| 86 }, "Delete earlier element in NodeList"); | |
| 87 | |
| 88 | |
| 89 test(function() { | |
| 90 let nodeList = form.radio; | |
| 91 let rad = rad2; | |
| 92 let id = 0; | |
| 93 for (let node of nodeList) { | |
| 94 assert_true(node instanceof HTMLInputElement, "elements should be expect ed types"); | |
| 95 assert_equals(node.id, "rad" + ++id, "elements should be the expected va lues"); | |
| 96 assert_false(node.id === "rad2", "deleted later elements should not be i terated"); | |
| 97 if (node === rad1) { | |
| 98 rad.remove(); | |
| 99 ++id; | |
| 100 } | |
| 101 } | |
| 102 form.insertBefore(rad, rad3); | |
| 103 }, "Delete later element in NodeList"); | |
| 104 | |
| 105 | |
| 106 if (window.testRunner) | |
| 107 container.style.display = "none"; | |
|
arv (Not doing code reviews)
2015/07/01 20:53:08
You could put your html into a <template> element
| |
| 108 </script> | |
| OLD | NEW |