1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
<!DOCTYPE HTML>
<title>Radio input cancel behavior reverts state</title>
<link rel="author" title="jeffcarp" href="mailto:gcarpenterv@gmail.com">
<link rel="help" href="https://html.spec.whatwg.org/#radio-button-state-(type=radio)">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
<script>
"use strict";
test(() => {
const input = document.createElement("input");
input.type = "radio";
document.body.appendChild(input);
const events = [];
input.addEventListener("change", () => {
events.push("change");
});
input.addEventListener("click", e => {
// cancel click event
e.preventDefault();
events.push("click");
});
input.addEventListener("input", () => {
events.push("input");
});
assert_false(input.checked);
input.click();
assert_false(input.checked);
// only click event called
assert_array_equals(events, ["click"]);
}, "radio input cancel behavior reverts state");
test(() => {
const form = document.createElement("form");
form.innerHTML = `
<input id="radio1" type="radio" name="radiogroup" checked>
<input id="radio2" type="radio" name="radiogroup">
`;
document.body.appendChild(form);
const inputs = form.querySelectorAll("input[type=radio]");
const events = [];
inputs.forEach(input => {
input.addEventListener("change", () => {
events.push(`${input.id} change`);
});
input.addEventListener("click", e => {
// cancel click event
e.preventDefault();
events.push(`${input.id} click`);
});
input.addEventListener("input", () => {
events.push(`${input.id} input`);
});
});
assert_true(inputs[0].checked);
assert_false(inputs[1].checked);
inputs[1].click();
assert_true(inputs[0].checked);
assert_false(inputs[1].checked);
// only click event called
assert_array_equals(events, ["radio2 click"]);
}, "radio input cancel behavior reverts previous selected radio input state");
</script>
|