jquery dom은 W3C 국제 조직의 웹 표준 집합인 문서 개체 모델을 나타냅니다. DOM은 JavaScript에서 HTML, XHTML 및 XML 문서를 읽고 변경할 수 있습니다.
추천: "jquery 비디오 튜토리얼"
DOM이란 무엇인가요?
페이지의 내용을 변경하려면 JavaScript가 HTML 문서의 모든 요소에 액세스할 수 있어야 합니다. HTML 요소를 추가, 이동, 변경 또는 제거하기 위한 메서드 및 속성과 함께 이 항목은 DOM(문서 개체 모델)을 통해 가져옵니다.
1998년 W3C는 DOM 사양의 첫 번째 버전을 출시했습니다. 이 사양을 사용하면 HTML 페이지의 모든 개별 요소에 액세스하고 조작할 수 있습니다.
모든 브라우저는 이 표준을 구현했기 때문에 DOM 호환성 문제를 찾는 것이 거의 불가능합니다. DOM은 JavaScript에서 HTML을 읽고 변경하는 데 사용할 수 있습니다. DOM Core의 출현은 다양한 HTML 요소의 속성을 설명하기 위해 좀 더 간결한 표기법을 제공하는 DOM Core보다 훨씬 이전에 등장했습니다.
예: HTML-DOM을 사용하여 양식 개체 메서드 가져오기: document.forms
CSS-DOM
CSS-DOM은 CSS에 대한 작업입니다. JavaScript에서 CSS-DOM 기술의 주요 기능은 스타일 객체의 다양한 속성을 얻고 설정하는 것입니다. 스타일 객체의 다양한 속성을 변경함으로써 웹 페이지는 다양한 효과를 나타낼 수 있습니다.
요소의 스타일 객체 글꼴 색상을 설정하는 방법: elements.style.color = “red”
JQuery의 DOM 연산;
노드 찾기
요소는 DOM
$(function(){ var $para = $("p"); // 获取<p>节点 var $li = $("ul li:eq(1)"); // 获取第二个<li>元素节点 var p_txt = $para.attr("title"); // 输出<p>元素节点属性title var ul_txt = $li.attr("title"); // 获取<ul>里的第二个<li>元素节点的属性title var li_txt = $li.text(); // 输出第二个<li>元素节点的text });
Insert 노드
노드 삭제:주의해야 할 점은 DOM의 innerHTML 속성과 동일합니다. 요소 삭제 시, 현재 요소에 하위 요소가 포함된 경우 함께 삭제되며, 요소 삭제 시에는 현재 삭제된 요소에 대한 참조를 반환하므로 해당 요소를 나중에 다시 사용할 수 있습니다.
$(function(){ var $li = $("ul li:eq(1)").remove(); // 获取第二个<li>元素节点后,将它从网页中删除。 $li.appendTo(“ul”); // 把刚才删除的又重新添加到<ul>元素里 }); //或 $(function(){ $("ul li").remove("li[title!=菠萝]"); //把<li>元素中属性title删除不等于"菠萝"的<li>元素删除 });
요소 지우기:
ul의 두 번째 li에 있는 모든 하위 노드를 지웁니다. 참고: 비어 있음과 제거의 차이점은 비어 있음은 요소 내의 하위 노드를 지우는 반면 요소 자체는 유지된다는 것입니다.
$(function(){ $("ul li:eq(1)").empty(); // 找到第二个<li>元素节点后,清空此元素里的内容 });
복사 노드:
복사된 새 요소에는 아무런 동작이 없습니다. 즉, 복제된 새 요소를 클릭하면 이전에 설정된 클릭 이벤트가 없습니다. 필요한 경우 매개변수 clone(을 전달할 수 있습니다. clone 메소드 true), 요소를 복사할 때 요소에 바인딩된 이벤트도 복사됨을 나타냅니다.
$(function(){ $("ul li").click(function(){ $(this).clone().appendTo("ul"); // 复制当前点击的节点,并将它追加到<ul>元素 }) });
교체 노드:
$(function(){ $("p").replaceWith("<strong>你最不喜欢的水果是?</strong>"); // 同样的实现: $("<strong>你最不喜欢的水果是?</strong>").replaceAll("p"); });
Wrap 노드: Wrap,wrapAll,wrapInner
$(function(){ $(“span”).wrap(“<strong></strong>”); })
실행 결과 코드:
<strong><span>选择你最喜欢的水果</span></strong> $("span").wrapAll("<strong></strong>");//以第一个为开始往后面紧贴 这个会破坏页面结构
실행 후 결과
<strong> <span>选择你最喜欢的水果</span> <span>选择你最喜欢的水果</span> </strong> <span>选择你最喜欢的水果</span> $("span").wrapInner ("<strong></strong>");
실행 후 결과
<span><strong>选择你最喜欢的水果</strong></span>
속성 연산
//取值 var p_txt = $("p").attr(“title”); //设置属性 //找到a元素且有其中含有字符串“link”,修改属性href为“index.html" $(function(){ $("a:contains('link')").attr("href",“index.html"); }) //如果想同时设置多个属性可以使用一下代码 $("a:contains('link')").attr({"href":“index.html","title":"test"}); //键值对 attr({"属性1":"值1","属性2":"值2","属性3":"值3"}) //删除属性 $(“a”).removeAttr(“title”);
참고: jQuery 이 함수는 html(), text(), height(), width(), val(), css() 등을 포함한 값 가져오기 및 설정 설정을 동시에 구현합니다.
스타일 작업
//读取和设置样式 使用属性方式 读取样式 var p_class = $(“p”).attr(“class”); //设置样式 $(“p”).attr(“class”,”high”);
참고: 속성 모드 사용 스타일을 설정하면 추가 효과를 얻으려면 addClass
를 사용하여 스타일을 추가할 수 있습니다.
스타일:
<style type="text/css"> .high {font-weight:bold; color:red; } .another{font-style:italic; color:blue;} </style>
html:
<p title="选择你最喜欢的水果" class="high">选择你最喜欢的水果</p> //class="height another" 样式也可以这样写,中间用空格隔开 jQuery: $(“p”).addClass(“another”);
참고: 스타일 설정은 두 가지 규칙을 따릅니다. 여러 요소가 각 요소 클래스 값에 추가되며 이는 해당 스타일을 병합하는 것과 같습니다. 서로 다른 클래스가 동일한 스타일 속성을 설정하면 후자가 전자를 재정의합니다.
스타일 제거
//移除样式 $(“p”).removeClass(“high”); //同时移除多个样式 $(“p”).removeClass(“high”).removeClass(“another”); //样式全部移除 $(“p”).removeClass(); Toggle
토글 이벤트는 스타일 설정 및 취소를 제어합니다. 처음 클릭하면 토글 이벤트 정의의 첫 번째 펑션 블록이 실행되고, 다음을 클릭하면 토글 이벤트 정의의 두 번째 펑션 블록이 실행됩니다. 두 번째.
$(function(){ $(“p”).toggle(function(){ //内置方法一 添加样式 $(this).addClass(“another”); },function(){ //内置方法二 删除样式 $(this).removeClass(“another”); }) }) //会一直循环
toggleClass 메소드에도 비슷한 기능이 있습니다
하이퍼링크를 클릭하면 스타일을 설정하는 코드가 실행됩니다. 이때 현재 스타일이 해당 스타일에 없으면 자동으로 판단됩니다. 요소에 스타일이 추가되고, 현재 요소에 스타일이 있으면 스타일이 삭제됩니다.
$(function(){ $(“#link”).click(function(){ $(“p”).toggleClass(“another”); return false; }) })
Set and get 괄호 안에 아무것도 없으면 그냥 가져오세요.
--HTML文本值 //取值 var p_html = $(“p”).html(); //设置 $(“p”).html(“<strong>选择你最喜欢的水果</strong>”); --text()方法 文本 //取值 var p_text = $(“p”).text(); //设置值 $(“p”).text(“选择你最喜欢的水果”); --val()方法 value //取值 var txt_value = $(this).val(); //设置值 $(this).val("");
노드 탐색
CSS-DOM
//取值 $(“p”).css(color); //设置值 $(“p”).css(“color”,”red”); //和attr一样可以一次设置多个样式 $(“p”).css({“color”:”red”,”background”:”#003333”}); //透明度设置 $(“p”).css(“opacity”,”0.5”);
위 내용은 제이쿼리 돔이 뭐야?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!