首頁  >  文章  >  web前端  >  jquery dom是什麼

jquery dom是什麼

藏色散人
藏色散人原創
2020-12-21 10:46:552824瀏覽

jquery dom是指文檔物件模型即Document Object Model,是W3C國際組織的一套Web標準,DOM可被JavaScript用來讀取、改變HTML、XHTML以及XML文檔。

jquery dom是什麼

推薦:《jquery影片教學

什麼是DOM?

要改變頁面的某個東西,JavaScript 就需要取得對 HTML 文件中所有元素進行存取的入口。這個入口,連同對 HTML 元素進行新增、移動、改變或移除的方法和屬性,都是透過文件物件模型來獲得的(DOM)。

在 1998 年,W3C 發布了第一版的 DOM 規格。這個規範允許存取和操作 HTML 頁面中的每一個單獨的元素。

所有的瀏覽器都執行了這個標準,因此,DOM 的相容性問題也幾乎難覓食蹤影了。 DOM 可被JavaScript 用來讀取、改變HTML、XHTML 以及XML 文件

HTML-DOM

HTML-DOM 在使用JavaScript和DOM為HTML檔案編寫腳本,有許多專屬於HTML -DOM的屬性. HTML-DOM的出現甚至比DOM Core還要早,它提供一些更簡潔的符號來描述各種HTML元素的屬性。

例如: 使用HTML-DOM來取得表單物件 的方法: document.forms

CSS-DOM

CSS-DOM是針對CSS的操作。在JavaScript中,CSS-DOM技術的主要作用是取得和設定style物件的各種屬性。透過改變style物件的各種屬性,可以讓網頁呈現出各種不同的效果

設定某個元素style物件字體顏色的方法: elements.style.color = “red”;

#JQuery中的DOM操作

查找節點

元素可以透過text()方法讀取其中的html內容,相當於DOM的innerHTML屬性

$(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 
});

插入節點

jquery dom是什麼

刪除節點:

#要注意的是,在刪除元素時,如果目前元素包含子元素,會一同刪除,並且在刪除元素時會傳回一個目前被刪除元素的引用,可以在以後再使用這些元素。

$(function(){
var $li = $("ul li:eq(1)").remove(); // 获取第二个<li>元素节点后,将它从网页中删除。
$li.appendTo(“ul”); // 把刚才删除的又重新添加到<ul>元素里
});
//或
$(function(){
$("ul li").remove("li[title!=菠萝]"); //把<li>元素中属性title删除不等于"菠萝"的<li>元素删除
});

清空元素:

清空了ul 中的第二個li中的所有後代節點。注意:empty和remove的區別,empty清空元素內的後代節點,元素本身保留。

$(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 ,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中有很多函數同時實作取值get,和設定set,包括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”);

注意:樣式設定遵循兩個規則如果個一個元素添加了多個class值時,就等於合併它們的樣式。如果不同的class設定了同一樣式屬性,則後者覆寫前者。

移除樣式

 //移除样式
    $(“p”).removeClass(“high”);
 //同时移除多个样式
    $(“p”).removeClass(“high”).removeClass(“another”);
//样式全部移除
    $(“p”).removeClass();
Toggle

toggle事件控制樣式設定和取消,第一次點擊時執行toggle事件定義中的第一個函數區塊,當第二次點擊時執行toggle事件定義中的第二個函數塊,以此類推。

$(function(){
    $(“p”).toggle(function(){        //内置方法一 添加样式
        $(this).addClass(“another”);            
    },function(){                //内置方法二 删除样式            
     $(this).removeClass(“another”);        
    })        
})   //会一直循环

toggleClass 方法有類似的功能

當超連結點擊時執行程式碼設定樣式,這時設定樣式時會自動判斷,如果目前樣式不在對應元素上則新增樣式,如果在目前元素上則刪除樣式。

$(function(){
    $(“#link”).click(function(){
        $(“p”).toggleClass(“another”);            
        return false;
    })        
})

設定與取得 括號裡面沒有就是取,有就是設定

--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("");

# 遍歷節點
jquery dom是什麼

CSS-DOM

#
  //取值
    $(“p”).css(color);
  //设置值
    $(“p”).css(“color”,”red”);
  //和attr一样可以一次设置多个样式
    $(“p”).css({“color”:”red”,”background”:”#003333”});
  //透明度设置
    $(“p”).css(“opacity”,”0.5”);

以上是jquery dom是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn