1. <sup id="1kcns"></sup>

    2. <rt id="1kcns"><legend id="1kcns"></legend></rt>
      国产AV巨作丝袜秘书,国产精品久久香蕉免费播放,国产草草影院ccyycom,涩涩爱狼人亚洲一区在线,日本阿v片在线播放免费,国产精品一区二区三区蜜臀,精品一区二区三区在线观看l,av深夜免费在线观看

      JQuery中的DOM操作(1)

      2019-5-24    seo達(dá)人

      如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點(diǎn)這里

      DOM樹

                                       

          在訪問頁面時,需要與頁面中的元素進(jìn)行交互式的操作。在操作中,元素的訪問是最頻繁、最常用的,主要包括對元素屬性、內(nèi)容、值CSS的操作。

      一、操作元素的屬性

      attr()   prop() 獲取或設(shè)置元素的屬性值

      兩者區(qū)別:簡單來說,對于HTML元素本身就帶有的固有屬性,在處理時,使用prop方法。對于HTML元素我們自己自定義的DOM屬性,在處理時,使用attr方法。

      針對屬性對象不同

      prop( )是針對Dom元素屬性,attr( )針對HTML元素屬性,和attribute與property區(qū)別一樣。

      用于設(shè)置的屬性值類型不同

      attr()函數(shù)操作的是文檔節(jié)點(diǎn)的屬性,因此設(shè)置的屬性值只能是字符串類型,如果不是字符串類型,也會調(diào)用其toString()方法,將其轉(zhuǎn)為字符串類型。

      prop()函數(shù)操作的是JS對象的屬性,因此設(shè)置的屬性值可以為包括數(shù)組和對象在內(nèi)的任意類型。

      應(yīng)用版本不同

      attr()是jQuery 1.0版本就有的函數(shù),prop()是jQuery 1.6版本新增的函數(shù)。毫無疑問,在1.6之前,你只能使用attr()函數(shù);1.6及以后版本,你可以根據(jù)實(shí)際需要選擇對應(yīng)的函數(shù)。

      其他不同

      對于表單元素的checked、selected、disabled等屬性,Attr()方法拿不到值,請使用prop()函數(shù)來設(shè)置或獲取checked、selected、disabled等屬性。對于其它能夠用prop()實(shí)現(xiàn)的操作,也盡量使用prop()函數(shù)。如下圖代碼:

      <!DOCTYPE html>
      <html>
      <head lang="en">
          <meta charset="UTF-8">
          <title></title>
          <script src="js/jquery-1.9.1.min.js"></script>
      </head>
      <body>
      <input type="button" id="btn1" value="按鈕">
      <input type="button" id="btn2" value="按鈕">
      <script>
          //操作元素的屬性
          //attr() prop()獲取或設(shè)置元素的屬性值
          $("#btn1").attr("value","按鈕1");//將#btn1的value值改為按鈕1
          $("#btn1").prop("value","按鈕2");//將#btn1的value值改為按鈕2
          console.log( $("input[type='button']").prop("value"));//獲取#btn1的value值,輸出為按鈕2
          console.log($("#btn2").attr("value"));//獲取#btn1的value值,輸出為按鈕
          //設(shè)置多個屬性值
          $("input[type='button']").prop({
              width:"200px",
              value:"hello"
          });//同時設(shè)置寬度為100px,value值為hello
          //根據(jù)輸出結(jié)果,width值設(shè)置失敗,value值設(shè)置成功
          console.log($("input[type='button']").prop("width"));//0
          console.log($("input[type='button']").attr("width"));//0
          $("input[type='button']").attr({
              width:"200px",
              value:"HELLO"
          })//同時設(shè)置寬度為200px,value值為HELLO
          //根據(jù)輸出結(jié)果可以看到,width和value均設(shè)置成功
          console.log($("input[type='button']").prop("width"));//0
          console.log($("input[type='button']").attr("width"));//200px
       
      //    var btn=$("input[type='button']");
      //    btn.attr("data-src","pink");
      //    console.log(btn.attr("data-src"));//pink
      //    console.log(btn.prop("data-src"));//undefined
          
          
          var btn=$("input[type='button']");
          btn.prop("data-src","pink");
          console.log(btn.attr("data-src"));//undefined
          console.log(btn.prop("data-src"));//pink
       
      </script>
      二、刪除元素的屬性

      removeAttr( name ) ,其中name為元素屬性的名稱

      removeProp( name ) ,其中name為元素屬性的名稱

       

      三、元素內(nèi)容的操作

      在JQuery中,操作元素內(nèi)容的方法包括html( )和text( )。前者與JavaScript中的innerHTML屬性類似,即獲取或設(shè)置元素的HTML內(nèi)容;后者類似于JavaScript中的innerText屬性,即獲取或設(shè)置元素的文本內(nèi)容。區(qū)別如下:

      語法格式 參數(shù)說明 功能描述
      html() 無參數(shù) 用于獲取元素的HTML內(nèi)容
      html(val) val參數(shù)為元素的HTML內(nèi)容 用于設(shè)置元素的HTML內(nèi)容
      text() 無參數(shù) 用于獲取元素 的文本內(nèi)容
      text(val) val參數(shù)為元素的文本內(nèi)容 用于設(shè)置元素的文本內(nèi)容
      <script>
          //js中的寫法 innerHTML  innerText
          var sd=document.getElementById("block");
          sd.innerText="小貓吃魚";
          console.log(sd.innerHTML);//小貓吃魚
          console.log(sd.innerText);//小貓吃魚
      //    //jquery  html()  text() 和js一致  獲取或設(shè)置元素的html值或文本值
          console.log($("#block").html());//小貓吃魚
          console.log($("#block").text());//小貓吃魚
          $("#block").text("小貓抓老鼠");//修改innerText內(nèi)容
          console.log($("#block").html());//小貓抓老鼠
          console.log($("#block").text());//小貓抓老鼠
          $("#block").html("小貓吃肉肉");//修改innerHTML內(nèi)容
          console.log($("#block").html());//小貓吃肉肉
          console.log($("#block").text());//小貓吃肉肉
      </script>
      四、操作表單元素的值

      val()   獲取或設(shè)置表單元素的value值

      <!DOCTYPE html>
      <html>
      <head lang="en">
          <meta charset="UTF-8">
          <title></title>
          <script src="js/jquery-1.9.1.min.js"></script>
      </head>
      <body>
      <input type="text" id="txt" value="請輸入...">
      <script>
          console.log( $("#txt").val());// 獲取#txt的value值  輸出為:請輸入...
          $("#txt").val("12345");//修改#txt的value值為12345
          console.log( $("#txt").val());//12345
      </script>
      </body>
      </html>
      五、元素樣式的操作

      1.直接設(shè)置元素樣式值

      在JQuery中,通過css()方法為某個指定的元素設(shè)置樣式值,語法格式如下:

      css(name,value) ,其中name為樣式名稱,value為樣式的值

      css()可以設(shè)置樣式也可以獲取樣式



      2.增加CSS類別

      通過addClass()方法增加元素類別的名稱,語法格式如下:

      addClass(class) ,其中參數(shù)class為類名稱,可以同時增加多個,用空格隔開即可,如addClass(class0 class1 class2 ...)

      3.刪除CSS類別

      與addClass()方法相對應(yīng),removeClass()方法用于刪除類別,語法格式與addClass()相同,如果不設(shè)定參數(shù),則刪除元素中的所有類名稱

      4.類別切換

      通過toggleClass()方法切換不同的元素類別,語法格式如下:

      toggleClass(class) ,其中參數(shù)class為類別名稱,其功能是當(dāng)元素中含有名稱為class的CSS類別時,刪除該類別,若沒有,則增加該類別

      <!DOCTYPE html>
      <html>
      <head lang="en">
          <meta charset="UTF-8">
          <title></title>
          <script src="js/jquery-1.9.1.min.js"></script>
      </head>
      <body>
      <button id="btn" class="btndata">按鈕</button>
      <script>
          $("#btn").addClass("btn1");//追加一個類名稱
          $("#btn").addClass("btn2 btn3");//追加多個類名稱
          $("#btn").removeClass("btn2 btn1");//移除類名稱
          $("#btn").removeClass();//移除所有類名稱
          $("#btn").toggleClass("btn1");//類的切換 toggleClass()  如果有類名稱則替換  如果沒有就添加
      </script>
      </body>
      </html>
      六、jquery操作子父節(jié)點(diǎn)

      children()  找父元素里面的子節(jié)點(diǎn)

      <!DOCTYPE html>
      <html>
      <head lang="en">
          <meta charset="UTF-8">
          <title></title>
          <script src="js/jquery-1.9.1.min.js"></script>
      </head>
      <body>
      <ul>
          <li class="lilist">1</li>
          <li class="lidata">2</li>
          <span>6</span>
          <li class="lilist">3</li>
          <span>5</span>
          <li class="lilist">4</li>
          <span>7</span>
      </ul>
      <script>
              console.log($("ul").children());//輸出ul 下的所有子節(jié)點(diǎn)
              console.log($("ul").children()[0]);//輸出ul下索引為0的子節(jié)點(diǎn)
              console.log($("ul>li").first());//輸出ul里面第一個li
              console.log($("ul>li").last());//輸出ul里面最后一個li
              console.log($("ul>li").eq(2));//eq()  根據(jù)索引找元素
              console.log($("ul>li").first().siblings(".lilist"));//找同胞元素  輸出和first()相同類名稱的元素
              console.log($("ul>li").eq(1).prev());//找當(dāng)前元素的前一個元素
              console.log($("ul>li").eq(2).prevAll("span"));//當(dāng)前元素前面的所有指定元素
              console.log($("ul>li").eq(2).prevAll());//當(dāng)前元素前面的所有元素
              console.log($("ul>li").eq(1).next());//找當(dāng)前元素的下一個元素
              console.log($("ul>li").eq(1).nextAll("li"));//當(dāng)前元素后面的所有指定元素
              console.log($("ul>li").eq(1).nextAll());//當(dāng)前元素后面的所有元素
              console.log($("ul>li").eq(0).is(".qq"));//is() 判斷當(dāng)前對象是誰  輸出true  or  false  當(dāng)前元素與類名稱相符  輸出true
      </script>
      </body>
      </html>
      七、JQuery中的尺寸問題

      下面以高度為例進(jìn)行說明

      <!DOCTYPE html>
      <html>
      <head lang="en">
          <meta charset="UTF-8">
          <title></title>
          <script src="js/jquery-1.9.1.min.js"></script>
          <style>
             .ss{
                 width: 200px;
                 height: 200px;
                 margin: 10px 10px;
                 padding: 20px 20px;
             }
          </style>
      </head>
      <body>
      <div class="ss"></div>
      <script>
              console.log($(".ss").height());//200  可視區(qū)域  不包括內(nèi)外邊距 
              console.log($(".ss").innerHeight());//240  包括內(nèi)邊距的距離  
              console.log($(".ss").outerHeight());//240  包括內(nèi)邊距的距離
      </script>
      </body>
      </html>
      藍(lán)藍(lán)設(shè)計(jì)m.payeee.cn )是一家專注而深入的界面設(shè)計(jì)公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 平面設(shè)計(jì)服務(wù)

      日歷

      鏈接

      個人資料

      存檔

      主站蜘蛛池模板: 欧美日产国产精品| 国产成人无码免费视频97| 中文字幕无码A片| 国产av日韩精品一区二区| 无码日韩做暖暖大全免费不卡| 五月丁香综合激情六月久久| 99精品国产中文字幕| 色偷偷亚洲女人天堂观看| 亚洲国内自拍| 亚洲精品成人无| 中文字幕麻豆一区二区| 亚洲男人在线天堂| 亚洲精品乱码久久观看网| 影音先锋在线资源无码| 久久久久亚洲AV成人网站软件| 亚洲乱码中文字幕综合久久 | 97无码人妻福利免费公开在线视频 | 亚洲成A| 人人妻碰人人免费| 亚洲一区在线成人av| 欧美精品aⅴ在线视频| 久久亚洲V无码专区成人| 国产稚嫩高中生呻吟激情在线视频| 亚洲综合国产一区二区三区| 亚洲AV无码专区首页第一页| 欧美日本精品一本二本三区| 日韩一区二区三区女优丝袜| 艳妇乳肉豪妇荡乳av| 影音先锋一区二区三区视频| 亚洲综合无码AV| 国产卡一卡二卡三免费入口| 日韩秘 无码一区二区三区| 亚洲阿天堂v在线有码| 欧美性爱自拍| 无码日韩av一区二区三区| 国产精品96久久久久久| 波多野结衣一卡二卡| 国产亚洲精品性爱视频| 久久久久久曰本av免费免费| 日本无码欧美一区精品久久| 美女辣图|