> 웹 프론트엔드 > JS 튜토리얼 > 제이쿼리 돔이 뭐야?

제이쿼리 돔이 뭐야?

藏色散人
풀어 주다: 2020-12-21 10:46:55
원래의
2852명이 탐색했습니다.

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(&#39;link&#39;)").attr("href",“index.html");        
})
//如果想同时设置多个属性可以使用一下代码
$("a:contains(&#39;link&#39;)").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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿