zoukankan      html  css  js  c++  java
  • 4月12日学习笔记——jQuery操作属性和样式

    • 区分 DOM 属性和元素属性

    1 <img src="images/image.1.jpg" id="hibiscus" alt="Hibiscus" class="classA" />

    通常开发人员习惯将id,src,alt等叫做这个元素的"属性"。我们将其称为"元素属性"。但是在解析成 DOM 对象时,实际浏览器最后会将标签元素解析成"DOM 对象", 并且将元素的"元素属性"存储为"DOM 属性",两者是有区别的。

    甚至有些"元素属性"和"DOM 属性"的名称都不一样,比如上面的元素属性 class, 转换为 DOM 属性后对应 className。

    牢记, 在 javascript 中我们可以直接获取或设置"DOM 属性":

    1 <script type="text/javascript">
    2     $(function() {
    3         var img1 = document.getElementById("hibiscus");
    4         alert(img1.alt);
    5         img1.alt = "Change the alt element attribute";
    6         alert(img1.alt);
    7         img1.className = "classB";
    8     })
    9 </script>

    所以如果要设置元素的 CSS 样式类, 要使用的是 DOM 属性"className"而不是元素属性"class"。


    • 操作"Dom 属性"

    在 jQuery 提供了each()函数用于遍历 jQuery 包装集,其中的this指针是一个 DOM 对象,所以我们可以应用这一点配合原生 javascript 来操作元素的 DOM 属性:

    1 $("img").each(function(index) {
    2     alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt);
    3     this.alt = "changed";
    4     alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt);
    5 });

    • 操作"元素属性"

    我们可以使用 javascript 中的getAttributesetAttribute来操作元素的"元素属性"。在 jQuery 中给你提供了attr()包装集函数, 能够同时操作包装集中所有元素的属性:

    虽然我们可以使用removeAttr(name)删除元素属性,但是对应的 DOM 属性是不会被删除的, 只会影响 DOM 属性的值.比如将一个input元素的readonly元素属性去掉,会导致对应的 DOM 属性变成false(即input变成可编辑状态).


    • 修改 CSS 类和样式

    下表是修改 CSS 类相关的 jQuery 方法:

    注意addClass(class)removeClass(classes)的参数可以一次传入多个 css 类, 用空格分割。removeClass 方法的参数可选, 如果不传入参数则移除全部 CSS 类。

    同样当我们想要修改元素的具体某一个 CSS 样式,即修改元素属性"style"时, jQuery 也提供了相应的方法:


    • 获取常用属性

    <!doctype html>
    <html lang="zh">
    <head>
      <meata charset="utf-8"/>
      <title>get object width</title>
      <script src="jquery-1.11.2.min.js"></script>
      <script>
        $(function() {
          alert("attr("width"):" + $("#testDiv").attr("width")); //undifined
          alert("css("width"):" + $("#testDiv").css("width")); //auto(ie6) 或 1264px(ff)
          alert("width():" + $("#testDiv").width()); //正确的数值 1264
          alert("style." +  $("#testDiv")[0].style.width); //空值
        })
      </script>
    </head>
    <body>
      <div id="testDiv">test text</div>
    </body>
    </html>

    我们希望获取测试图层的宽度,使用 attr 方法获取"元素特性"为 undefined, 因为并没有为 div 添加 width。而使用 css()方法虽然可以获取到 style 属性的值, 但是在不同浏览器里返回的结果不同,IE6 下返回 auto,而 FF 下虽然返回了正确的数值但是后面带有"px"。所以 jQuery 提供了 width()方法,此方法返回的是正确的不带 px 的数值。

    针对上面的问题,jQuery 为常用的属性提供了获取和设置的方法,比如 width()用户获取元素的宽度,而 width(val)用来设置元素宽度。

    下面这些方法可以用来获取元素的常用属性值:

    1. 宽和高相关 Height and Width

         

    outerWidth 可以接受一个 bool 值参数表示是否计算 margin 值。

    2. 位置相关 Positioning

  • 相关阅读:
    【Matlab系列】之基于元胞自动机的城市规划(程序修正)
    【Bug】 Access Violation exception&First-chance exception
    【Bug】缓冲区溢出检查_security_cookie
    【PE】x264编解码器在Windows(MinGw环境)和Linux平台的编译过程以及使用方法
    【C】printf()详解
    【Linux】Linux下没有 itoa
    【AVS】AVS2编码器开源啦:xAVS2
    【OS】关于堆、栈生长方向和大小端模式
    【PE/Python】python IDLE添加行号显示
    【C】将数字转换为字符串的方法
  • 原文地址:https://www.cnblogs.com/little-jelly/p/5383001.html
Copyright © 2011-2022 走看看