HTML DOM Bindings for the FxJS
<div class="container div1" active="true">
<ul class="list1">
<li class="item1">1</li>
<li class="item2">2</li>
<li class="item3">3</li>
</ul>
<div class="div2" active="true">
<ul class="list2">
<li class="item4">4</li>
<li class="item5">5</li>
</ul>
</div>
</div>$λ document.querySelectorλ₯Ό μ¬μ©νκ³ $.allμ document.querySelectorAllμ μ¬μ©ν©λλ€.
console.log($(".container li"));
// li.item1
console.log($.all(".container li"));
// NodeList(5)Β [li.item1, li.item2, li.item3, li.item4, li.item5]$.findλ el.querySelectorλ₯Ό μ¬μ©νκ³ $.findAllμ el.querySelectorAllμ μ¬μ©ν©λλ€.
console.log($.find("li", $(".container div")));
// li.item4
console.log($.findAll("li", $(".container div")));
// NodeList(2)Β [li.item4, li.item5]
console.log($.find("li", $(".container")));
// li.item1
console.log($.findAll("li", $(".container")));
// NodeList(5)Β [li.item1, li.item2, li.item3, li.item4, li.item5]
console.log($.findAll("ul li", $(".container")));
// NodeList(5)Β [li.item1, li.item2, li.item3, li.item4, li.item5]el.querySelectorλ el.querySelectorAllμ κ²½μ°λ μ
λ ν°μ μμμΌλ‘ >λ₯Ό μ¬μ©ν μ μμ΅λλ€.
try {
document.querySelector(".container").querySelectorAll("> ul li");
} catch (e) {
console.log(e);
// DOMException: Failed to execute 'querySelectorAll' on 'Element': '> ul li' is not a valid selector.
}el.querySelectorλ el.querySelectorAllμ κ²½μ°λ μ
λ ν°μ μμμ΄ λΆλͺ¨λ ν¬ν¨νκ³ , μμμμλ ν¬ν¨νλ€λ μ μ μ μν΄μΌν©λλ€.
console.log(
document.querySelector(".container").querySelectorAll("[active=true] > ul li")
);
// NodeList(5)Β [li.item1, li.item2, li.item3, li.item4, li.item5]μλ μμ λ $.find, $.findAllμ el.querySelectorλ el.querySelectorAllμ μ°¨μ΄λ₯Ό 보μ¬μ€λλ€.
-
$.find, $.findAllμ>λ₯Ό μ λ ν°μ μμμΌλ‘ μ¬μ©ν μ μμ΅λλ€. -
&λ₯Ό ν΅ν΄ λΆλͺ¨ elementμ λν΄μλ§ μΆκ° 쑰건μ λΆμΌ μ μμ΅λλ€.
console.log($.findAll("> ul li", $(".container")));
// NodeList(5)Β [li.item1, li.item2, li.item3]
console.log($.findAll('&[active="true"] li', $(".container")));
// NodeList(5)Β [li.item1, li.item2, li.item3, li.item4, li.item5]
console.log($.findAll('&[active="true"] > ul li', $(".container")));
// NodeList(5)Β [li.item1, li.item2, li.item3]
console.log($.findAll('&[active="false"] li', $(".container")));
// NodeList()Β []μμ μ ν¬ν¨νμ¬ μ λ ν°μ λ§€μΉλλ λΆλͺ¨ μ리먼νΈλ₯Ό μ°Ύμ΅λλ€.
console.log($.closest("li", $(".item4")));
// li.item4
console.log($.closest("ul", $(".item4")));
// ul.list2
console.log($.closest("div", $(".item4")));
// div.div2
console.log($.closest("div.container", $(".item4")));
// div.container.div1첫 λ²μ§Έ μΈμμ μ λ¬λ μ λ ν°μ λ§€μΉμ΄ λλμ§ νμΈν©λλ€.
console.log($.is(".item1", $("li:nth-child(1)")));
// true
console.log($.is(".item1", $("li:nth-child(2)")));
// trueconsole.log($.els('<span class="s1">1</span>'));
// HTMLCollection(2)Β [span.s1]
console.log($.els('<span class="s1">1</span><span class="s2">2</span>'));
// HTMLCollection(2)Β [span.s1, span.s2]console.log($.el('<span class="s1">1</span>'));
// span.s1
console.log($.el('<span class="s1">1</span><span class="s2">2</span>'));
// span.s1$.appendTo($(".comments"), $.el('<div class="comment">μ λκΈ</div>'));$.prependTo($(".posts"), $.el('<div class="post">μ κΈ</div>'));$.append($.el('<div class="comment">μ λκΈ</div>'), $(".comments"));$.prepend($.el('<div class="post">μ κΈ</div>'), $(".posts"));$.remove($(".post"));console.log($.text($.el("<div>hi</div>")));
// "hi"console.log($.setText("ho", $.el("<div></div>")));
// HTMLDivElement <div>ho</div>console.log($.html($.el("<div><span>hi</span></div>")));
// "<span>hi</span>"console.log($.setHTML("<span>ho</span>", $.el("<div></div>")));
// HTMLDivElement <div><span>ho</span></div>console.log($.outerHTML($.el("<div><span>hi</span></div>")));
// "<div><span>hi</span></div>"let el = $("#div1");
$.setOuterHTML('<div id="div1" class="hi2"></div>', el);
console.log($("#div1"));
// HTMLDivElement <div id="div1" class="hi2"></div>console.log($.val($.el('<input type="text" value="hoho">')));
// "hoho"console.log($.setVal("hoho", $.el('<input type="text">')).value);
// "hoho"console.log($.attr("type", $.el('<input type="text" value="hoho">')));
// "text"console.log($.setAttr({ status: "ho" }, $.el('<div status="hi">')));
// HTMLDivElement <div status="ho"></div>
console.log(
$.setAttr({ status: "ho", class: "ye" }, $.el('<div status="hi">'))
);
// HTMLDivElement <div status="ho" class="ye"></div>
console.log($.setAttr(["status", "ho"], $.el('<div status="hi">')));
// HTMLDivElement <div status="ho"></div>
console.log($.setAttr({ status: "" }, $.el('<div status="hi">')));
// HTMLDivElement <div status></div>console.log($.removeAttr("status", $.el('<div status="hi">')));
// HTMLDivElement <div></div>console.log($.addClass("selected", $.el("div")));
// HTMLDivElement <div class="selected"></div>
console.log($.addClass("hi ho", $.el("div")));
// HTMLDivElement <div class="hi ho"></div>
console.log($.addClass("hi", $.el('<div class="ye">')));
// HTMLDivElement <div class="ye hi"></div>console.log($.removeClass("selected", $.el('<div class="selected"></div>')));
// HTMLDivElement <div class></div>
console.log($.removeClass("hi ho", $.el('<div class="hi ho"></div>')));
// HTMLDivElement <div class></div>
console.log($.removeClass("hi", $.el('<div class="ye hi">')));
// HTMLDivElement <div class="ye"></div>console.log($.toggleClass("selected", $.el('<div class="selected"></div>')));
// HTMLDivElement <div class></div>
console.log($.toggleClass("selected", $.el("<div></div>")));
// HTMLDivElement <div class="selected"></div>console.log($.hasClass("selected", $.el('<div class="selected"></div>')));
// true
console.log($.hasClass("a", $.el('<div class="b"></div>')));
// falseconsole.log(
$.offset(
$.append(
$("body"),
$.setCss(
{
position: "absolute",
top: "20px",
left: "30px",
"margin-top": "50px",
},
$.el("div")
)
)
)
);
// { top: 70, left: 30 }width
height
width + paddingLeft + paddingRight + borderLeft + borderRight
height + paddingTop + paddingBottom + borderTop + borderBottom
innerWidth + marginLeft + marginRight
innerHeight + marginTop + marginBottom
$.onμ el.addEventListenerλ₯Ό λμ ν©λλ€. $.onμ μ΄λ²€νΈλ₯Ό λ±λ‘ν ν¨μλ₯Ό 리ν΄νλ©°, μ»€λ§ λ°©μμΌλ‘λ§ μ¬μ©ν μ μμ΅λλ€.
- μΈμλ‘ λ°μ ν¨μλ₯Ό μ‘°μνμ§ μκ³
el.addEventListenerμ κ·Έλλ‘ μ μ©νμ¬, κ°μ μ리먼νΈμ κ°μ μ΄λ²€νΈμ κ°μ ν¨μλ₯Ό λ±λ‘μ΄ λμ§ μλel.addEventListenerμ νΉμ§μ κ·Έλλ‘ μ μ§νμ΅λλ€. el.addEventListenerμcapture,passiveλ±μ μ΅μ μ μ¬μ©ν μ μμ΅λλ€.e.preventDefault,e.stopPropagationμ μ¬μ©ν μ μμ΅λλ€.el.removeEventListenerμ$.offλ₯Ό μ¬μ©ν μ μμ΅λλ€.
<button type="button" id="btn1">
<span>btn1</span>
</button>const addClickEvent = $.on("click", function (e) {
console.log(e.currentTarget); // #btn1
console.log(e.target); // span
});
addClickEvent($("#btn1"));
addClickEvent($("#btn1")); // λ λ² λ±λ‘ν΄λ μΆκ°λ‘ λ±λ‘λμ§ μμ.
$.trigger("click", $("#btn1 span"));
// #btn1
// span$.onμ λ λ²μ§Έ μΈμμ μ
λ ν°λ₯Ό μ λ¬νλ©΄ λ§€μΉλλ μμμμμ μ΄λ²€νΈλ₯Ό λ±λ‘ν©λλ€. μ΄ λ°©μμ μμ λ°©μμ΄ μλλ©°, μμ el.addEventListenerμ μ£Όμ νΉμ§κ³Ό κΈ°λ₯μ λͺ¨λ μ¬μ©ν μ μμ΅λλ€.
<div class="articles">
<div class="article">
<button type="button" class="remove"><span>μμ </span></button>
</div>
<div class="article">
<button type="button" class="remove"><span>μμ </span></button>
</div>
</div>const Articles = {
addEvents: pipe(
$.on("click", ".article:nth-child(1)", function (e) {
console.log(e.currentTarget);
}),
$.on(
"click",
".article",
function (e) {
console.log(e.currentTarget);
},
{ capture: true }
),
$.on("click", ".remove", function (e) {
console.log("other_data:", e.other_data);
console.log(e.currentTarget);
})
),
};
Articles.addEvents($(".articles"));
$.trigger("click", $(".articles .article:nth-child(1) .remove")); // ν λ²λ§ μ€ν
// other_data: undefined
// button.remove
// div.article
$.trigger("click", $(".articles .article:nth-child(2) .remove"));
// div.article
// other_data: undefined
// button.remove
$.append(
$(".articles"),
$.el(`
<div class="article new">
<button type="button" class="remove"><span>μμ </span></button>
</div>
`)
);
Articles.addEvents($(".articles"));
$.trigger("click", $(".articles .article:nth-child(1) .remove")); // ν λ²λ§ μ€ν
// other_data: undefined
// button.remove
// div.article
$.trigger("click", $(".articles .article:nth-child(3) .remove"));
// div.article.new
// other_data: undefined
// button.remove
$.trigger(
"click",
{ other_data: "hi" },
$(".articles .article:nth-child(3) .remove")
);
// div.article.new
// other_data: hi
// button.remove$.onμ μ λ¬ν λͺ¨λ μΈμλ₯Ό λμΌνκ² μ λ¬νμ¬ μ΄λ²€νΈλ₯Ό μ§μΈ μ μμ΅λλ€.
<button type="button" id="btn2"></button>const eventArgs = [
"click",
function () {
console.log("hi~");
},
];
$.on(...eventArgs)($("#btn2"));
$.off(...eventArgs)($("#btn2"));
$.trigger("click", $("#btn2"));
// nothingμ΄λ²€νΈ μμ λ°©μμΌλ‘ μ΄λ²€νΈλ₯Ό λ±λ‘ν©λλ€. μ΄λ²€νΈλ₯Ό λ±λ‘νκ³ μ νλ μ리먼νΈκ° λμ μΌλ‘ κ°νΈνκ² μ΄λ²€νΈλ₯Ό λ±λ‘ν΄λ μ μμ΅λλ€.
<div class="users"></div>go(
$(".users"),
$.delegate("click", ".remove", function () {
console.log("remove user");
})
);
$.append(
$(".users"),
$.el(`
<div class="user new">
<button type="button" class="remove"><span>μμ </span></button>
</div>
`)
);
$.trigger("click", $(".users .remove"));
// remove userμ΄λ²€νΈ μμ λ°©μμ μλμ κ°μ μ΅μ λ€μ μ¬μ©ν νμκ° μλ μν©μ ννμ¬ μ¬μ©νλ κ²μ κΆμ₯ν©λλ€.
el.addEventListenerμcapture,passiveλ±μ μ΅μ μ μ¬μ©ν μ μμ΅λλ€.e.preventDefault,e.stopPropagationμ μ¬μ©ν μ μμ΅λλ€.el.removeEventListenerμ$.offλ₯Ό μ¬μ©ν μ μμ΅λλ€.mouseleave,mouseenterλ μ μ λμνμ§ μμ΅λλ€.
don.jsμμλ μ΄λ²€νΈ μμ λ°©μμμ μ κΈ°λ₯λ€μ λͺ¨λ ꡬννμ¬ μ 곡νμ§λ§, μ¬μ€μ λΈλΌμ°μ μ μ΄λ²€νΈμ λν λͺ¨λ λμμ λΌμ΄λΈλ¬λ¦¬ μμ λ€μ ꡬννλ μ₯ν©ν μ½λλ€μ΄ νμνλ©°, κ²½νμ κ·Έ μ€μ©μ±μ΄ λ¨μ΄μ§λ€κ³ μκ°νμ¬ FxDOMμ ν΄λΉ κΈ°λ₯μ ꡬννμ§ μλ 컨μ μΌλ‘ κ°κ³ μ ν©λλ€.
<div class="signup" agree="false">
<input type="checkbox" />
<button type="button">κ°μ
</button>
</div>go(
$(".signup"),
$.delegate("change", "input", function (e) {
$.setAttr({ agree: e.currentTarget.checked }, e.delegateTarget);
}),
$.delegate("click", '&[agree="false"] button', function () {
console.log("λμν΄μ£ΌμΈμ!");
}),
$.delegate("click", '&[agree="true"] button', function () {
console.log("κ°μ¬ν©λλ€!");
})
);
$.trigger("click", $(".signup button"));
// λμν΄μ£ΌμΈμ!
$.trigger("click", $(".signup input"));
$.trigger("click", $(".signup button"));
// κ°μ¬ν©λλ€!<div class="item" data-fx-json='{"id": 1, "active": true}'></div>
<div class="item2"></div>const { id, active } = $.data($(".item"));
console.log(id, active);
// 1 true
const data = $.data($.setData({ id: 1, active: false }, $(".item")));
console.log(data.active);
// false
data.active = true;
console.log($.data($(".item")).active);
// trueconst data = { id: 1, active: true };
const item = document.createElement(
`<div class="item" data-fx-json="${$.dataStr(data)}">`
);
const { id, active } = $.data(item);
console.log(id, active);
// 1 true$.get, $.post, $.put, $.deleteμ Content-Typeμ application/jsonμΌλ‘ μ€μ λμ΄μμΌλ©° μλ΅μ΄ μ€λ©΄ JSON κ°μ²΄λ₯Ό λ°νν©λλ€. 4κ° ν¨μ λͺ¨λ νμ μΈμλ 2κ° μ΄μμ΄λ©°, μΈμλ₯Ό 1κ°λ§ μ λ¬νλ©΄ ν¨μλ₯Ό 리ν΄ν©λλ€.
$.get("/api/posts", { offset: 0, limit: 10 }); // GET '/api/posts?offset=0&limit10'
// Promise [{id: 1, ...}, {id: 2, ...}, ...]$.post("/api/posts", { content: "ho~" }); // POST /api/posts, BODY { content: 'ho~' }
// Promise {id:1, content: 'ho', created_at: ... }$.put(`/api/posts/${post.id}`, post); // PUT /api/posts/1, BODY { id: 1, ... }
// Promise {id:1, content: 'ho', updated_at: ... }$.delete(`/api/posts/${post.id}`, undefined); // DELETE /api/posts/1