一、获得内容及属性

三个简单实用的用于 DOM 操作的 jQuery 方法:

  • text() - 设置或返回所选元素的文本内容
  • html() - 设置或返回所选元素的内容(包括 HTML 标记)
  • val() - 设置或返回表单字段的值

下面的例子演示如何通过 jQuery text() 和 html() 方法来获得内容:

  1. $("#btn1").click(function(){
  2. alert("Text: " + $("#test").text());
  3. });
  4. $("#btn2").click(function(){
  5. alert("HTML: " + $("#test").html());
  6. });

下面的例子演示如何通过 jQuery val() 方法获得输入字段的值:

  1. $("#btn1").click(function(){
  2. alert("值为: " + $("#test").val());
  3. });

获取属性的值

jQuery attr() 方法用于获取属性值。

下面的例子演示如何获得链接中 href 属性的值:

  1. $("button").click(function(){
  2. alert($("#runoob").attr("href"));
  3. });

二、设置内容和属性

我们将使用前一章中的三个相同的方法来设置内容:

  • text() - 设置或返回所选元素的文本内容
  • html() - 设置或返回所选元素的内容(包括 HTML 标记)
  • val() - 设置或返回表单字段的值

下面的例子演示如何通过 text()、html() 以及 val() 方法来设置内容:

  1. $("#btn1").click(function(){
  2. $("#test1").text("Hello world!");
  3. });
  4. $("#btn2").click(function(){
  5. $("#test2").html("<b>Hello world!</b>");
  6. });
  7. $("#btn3").click(function(){
  8. $("#test3").val("RUNOOB");
  9. });

text()、html() 以及 val() 的回调函数

上面的三个 jQuery 方法:text()、html() 以及 val(),同样拥有回调函数。回调函数有两个参数:被选元素列表中当前元素的下标,以及原始(旧的)值。然后以函数新值返回您希望使用的字符串。

下面的例子演示带有回调函数的 text() 和 html():

  1. $("#btn1").click(function(){
  2. $("#test1").text(function(i,origText){
  3. return "旧文本: " + origText + " 新文本: Hello world! (index: " + i + ")";
  4. });
  5. });
  6.  
  7. $("#btn2").click(function(){
  8. $("#test2").html(function(i,origText){
  9. return "旧 html: " + origText + " 新 html: Hello <b>world!</b> (index: " + i + ")";
  10. });
  11. });

设置属性 - attr()

jQuery attr() 方法也用于设置/改变属性值。

下面的例子演示如何改变(设置)链接中 href 属性的值:

  1. $("button").click(function(){
  2. $("#runoob").attr("href","http://www.runoob.com/jquery");
  3. });

attr() 方法也允许您同时设置多个属性。

下面的例子演示如何同时设置 href 和 title 属性:

  1. $("button").click(function(){
  2. $("#runoob").attr({
  3. "href" : "http://www.runoob.com/jquery",
  4. "title" : "jQuery 教程"
  5. });
  6. });

移除attr:removeAttr, prop

下面的例子删除属性:

  1. $("#runoob").removeAttr("href")
  2. $("#runoob").prop("title")

例子:禁用页面所有的复选框:

  1. $("input[type='checkbox']").prop({
  2. disabled: true
  3. });

禁用和选中所有页面上的复选框,disabled:true表示禁用,checked:true表示选中。

  1. $("input[type='checkbox']").prop("disabled", true);
  2. $("input[type='checkbox']").prop("checked", true);

实例:全部选择、全部取消、反选

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <input type="button" value="全选" onclick="SelectAll();">
  9. <input type="button" value="取消" onclick="Cancel();">
  10. <input type="button" value="反选" onclick="Reverse();">
  11. <table>
  12. <tr>
  13. <td><input type="checkbox"></td>
  14. <td>请选择</td>
  15. </tr>
  16. <tr>
  17. <td><input type="checkbox"></td>
  18. <td>请选择</td>
  19. </tr>
  20. <tr>
  21. <td><input type="checkbox"></td>
  22. <td>请选择</td>
  23. </tr>
  24. <tr>
  25. <td><input type="checkbox"></td>
  26. <td>请选择</td>
  27. </tr>
  28. </table>
  29. <script src="jquery.js"></script>
  30. <script>
  31. function SelectAll() {
  32. $("table input").prop("checked",true)
  33. }
  34. function Cancel() {
  35. $("table input").prop("checked",false)
  36. }
  37. function Reverse() {
  38. $("table input").each(
  39. function () {
  40. if($(this).prop("checked")){
  41. $(this).prop("checked",false)
  42. }else{
  43. $(this).prop("checked",true)
  44. }
  45. }
  46. )
  47. }
  48. </script>
  49. </body>
  50. </html>

全选、取消、反选

实例中涉及两种循环,jQuery中涉及两种循环方式:

1、循环每个元素,在回调函数中可以用this表示当前循环的元素

1)each函数中的return相当于for循环中的continue,只是结束当前循环

2)each函数中的return false是结束each中的函数,主函数并不结束

3)如果想结束主函数,则在each循环外部加 return

  1. function Reverse() {
  2. $("table input").each(
  3. function () {
  4. if($(this).prop("checked")){
  5. $(this).prop("checked",false)
  6. }else{
  7. $(this).prop("checked",true)
  8. }
  9. }
  10. )
  11. }

2、循环数组(i,v),i表示循环的索引,v表示循环的值

  1. li = [11,22,33,44,55]
  2. $.each(li,function (i,v) {
  3. console.log(i,v)
  4. })
  5. //结果输出
  6. //0 11
  7. //1 22
  8. //2 33
  9. //3 44
  10. //4 55

attr() 的回调函数

jQuery 方法 attr(),也提供回调函数。回调函数有两个参数:被选元素列表中当前元素的下标,以及原始(旧的)值。然后以函数新值返回您希望使用的字符串。

下面的例子演示带有回调函数的 attr() 方法:

  1. $("button").click(function(){
  2. $("#runoob").attr("href", function(i,origValue){
  3. return origValue + "/jquery";
  4. });
  5. });

 attr的坑

以下代码,在cosole中执行:

$("#d2").attr("checked","checked")  //会选中复选框

$("#d2").removeAttr("checked")  //会取消复选框

$("#d2").attr("checked","checked") //取消后,再次执行这句代码,则不会选中,

所以设置和取消建议使用:

$("#d2").prop("checked",true)

$("#d2").prop("checked",false)

  1. <body>
  2. <input type="checkbox" checked="checked">
  3. <input id="d2" type="checkbox">
  4. <script src="jquery.js"></script>
  5. <script>
  6. </script>
  7. </body>

三、jquery添加元素

通过 jQuery,可以很容易地添加新元素/内容。

添加新的 HTML 内容

我们将学习用于添加新内容的四个 jQuery 方法:

  • append() - 在被选元素的结尾插入内容
  • prepend() - 在被选元素的开头插入内容
  • after() - 在被选元素之后插入内容
  • before() - 在被选元素之前插入内容

jQuery append() 方法:

jQuery append() 方法在被选元素的结尾插入内容(仍然该元素的内部)。

  1. $("p").append("追加文本");

jQuery prepend() 方法

jQuery prepend() 方法在被选元素的开头插入内容。

  1. $("p").prepend("在开头追加文本");

通过 append() 和 prepend() 方法添加若干新元素

在上面的例子中,我们只在被选元素的开头/结尾插入文本/HTML。

不过,append() 和 prepend() 方法能够通过参数接收无限数量的新元素。可以通过 jQuery 来生成文本/HTML(就像上面的例子那样),或者通过 JavaScript 代码和 DOM 元素。

在下面的例子中,我们创建若干个新元素。这些元素可以通过 text/HTML、jQuery 或者 JavaScript/DOM 来创建。然后我们通过 append() 方法把这些新元素追加到文本中(对 prepend() 同样有效):

  1. function appendText()
  2. {
  3. var txt1="<p>文本。</p>"; // 使用 HTML 标签创建文本
  4. var txt2=$("<p></p>").text("文本。"); // 使用 jQuery 创建文本
  5. var txt3=document.createElement("p");
  6. txt3.innerHTML="文本。"; // 使用 DOM 创建文本 text with DOM
  7. $("body").append(txt1,txt2,txt3); // 追加新元素
  8. }

jQuery after() 和 before() 方法

jQuery after() 方法在被选元素之后插入内容。

jQuery before() 方法在被选元素之前插入内容。

  1. $("img").after("在后面添加文本");
  2.  
  3. $("img").before("在前面添加文本");

通过 after() 和 before() 方法添加若干新元素

after() 和 before() 方法能够通过参数接收无限数量的新元素。可以通过 text/HTML、jQuery 或者 JavaScript/DOM 来创建新元素。

在下面的例子中,我们创建若干新元素。这些元素可以通过 text/HTML、jQuery 或者 JavaScript/DOM 来创建。然后我们通过 after() 方法把这些新元素插到文本中(对 before() 同样有效):

  1. function afterText()
  2. {
  3. var txt1="<b>I </b>"; // 使用 HTML 创建元素
  4. var txt2=$("<i></i>").text("love "); // 使用 jQuery 创建元素
  5. var txt3=document.createElement("big"); // 使用 DOM 创建元素
  6. txt3.innerHTML="jQuery!";
  7. $("img").after(txt1,txt2,txt3); // 在图片后添加文本
  8. }

那有木有考虑过append/prepend和after/before有什么区别呢?

append

  1. <p>
  2. <span class="s1">s1</span>
  3. </p>
  4. <script>
  5. $("p").append('<span class="s2">s2</span>');
  6. </script>

结果是这样的:

  1. <p>
  2. <span class="s1">s1</span>
  3. <span class="s2">s2</span>
  4. </p>

after

  1. <p>
  2. <span class="s1">s1</span>
  3. </p>
  4. <script>
  5. $("p").after('<span class="s2">s2</span>');
  6. </script>

结果是这样的:

  1. <p>
  2. <span class="s1">s1</span>
  3. </p>
  4. <span class="s2">s2</span>

总结:

append/prepend 是在选择元素内部嵌入。

after/before 是在元素外面追加。

另外还有

appendTo() 效果与append相同

  1. $('<span class="s2">s2</span>').appendTo("p");

prependTo()效果与prepend相同

  1. $('<span class="s2">s2</span>').preppendTo("p");

insertBefor()效果与befor相同

  1. $('<span class="s2">s2</span>').insertBefor("p");

inserAfter()效果与after相同

  1. $('<span class="s2">s2</span>').insertAfter("p");

replaceWith()

用于将匹配元素替换掉的内容。如果这里传递一个函数进来的话,函数返回值必须是HTML字符串。

  1. <p>Hello</p>
    <p>cruel</p>
    <p>World</p>
  1. $("p").replaceWith("<b>Paragraph. </b>");
    结果:
  1. <b>Paragraph. </b>
    <b>Paragraph. </b>
    <b>Paragraph. </b>

clone()

  1. $("b").clone().prependTo("p");

四、jQuery - 删除元素

通过 jQuery,可以很容易地删除已有的 HTML 元素。

删除元素/内容

如需删除元素和内容,一般可使用以下两个 jQuery 方法:

  • remove() - 删除被选元素(及其子元素)
  • empty() - 从被选元素中删除子元素

jQuery remove() 方法

jQuery remove() 方法删除被选元素及其子元素。

  1. $("#div1").remove();

jQuery empty() 方法

jQuery empty() 方法删除被选元素的子元素。

  1. $("#div1").empty();

过滤被删除的元素

jQuery remove() 方法也可接受一个参数,允许您对被删元素进行过滤。

该参数可以是任何 jQuery 选择器的语法。

下面的例子删除 class="italic" 的所有 <p> 元素:

  1. $("p").remove(".italic");

 五、jQuery - 获取并设置CSS类

通过 jQuery,可以很容易地对 CSS 元素进行操作。

jQuery操作CSS

jQuery 拥有若干进行 CSS 操作的方法。我们将学习下面这些:

  • addClass() - 向被选元素添加一个或多个类
  • removeClass() - 从被选元素删除一个或多个类
  • toggleClass() - 对被选元素进行添加/删除类的切换操作
  • css() - 设置或返回样式属性

实例样式表:

  1. .important
  2. {
  3. font-weight:bold;
  4. font-size:xx-large;
  5. }
  6.  
  7. .blue
  8. {
  9. color:blue;
  10. }

jQuery addClass() 方法

下面的例子展示如何向不同的元素添加 class 属性。当然,在添加类时,您也可以选取多个元素:

  1. $("button").click(function(){
  2. $("h1,h2,p").addClass("blue");
  3. $("div").addClass("important");
  4. });

您也可以在 addClass() 方法中规定多个类:

  1. $("button").click(function(){
  2. $("body div:first").addClass("important blue");
  3. });

jQuery removeClass() 方法

下面的例子演示如何在不同的元素中删除指定的 class 属性:

  1. $("button").click(function(){
  2. $("h1,h2,p").removeClass("blue");
  3. });

jQuery toggleClass() 方法

下面的例子将展示如何使用 jQuery toggleClass() 方法。该方法对被选元素进行添加/删除类的切换操作:

  1. $("button").click(function(){
  2. $("h1,h2,p").toggleClass("blue");
  3. });

实例:切换加载和删除类

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js">
  6. </script>
  7. <script>
  8. $(document).ready(function(){
  9. $("button").click(function(){
  10. $("h1,h2,p").toggleClass("blue");
  11. });
  12. });
  13. </script>
  14. <style type="text/css">
  15. .blue
  16. {
  17. color:blue;
  18. }
  19. </style>
  20. </head>
  21. <body>
  22.  
  23. <h1 class="blue">标题 1</h1>
  24. <h2 class="blue">标题 2</h2>
  25. <p class="blue">这是一个段落。</p>
  26. <p>这是另外一个段落。</p>
  27. <br>
  28. <button>切换 class</button>
  29. </body>
  30. </html>

来回切换加载删除css类样式

 jQuery css()方法

css() 方法设置或返回被选元素的一个或多个样式属性。

返回css属性

如需返回指定的 CSS 属性的值,请使用如下语法:

  1. css("propertyname");

下面的例子将返回首个匹配元素的 background-color 值:

  1. $("p").css("background-color");

设置css属性

如需设置指定的 CSS 属性,请使用如下语法:

  1. css("propertyname","value");

下面的例子将为所有匹配元素设置 background-color 值:

  1. $("p").css("background-color","yellow");

设置多个 CSS 属性

如需设置多个 CSS 属性,请使用如下语法:

  1. css({"propertyname":"value","propertyname":"value",...});

下面的例子将为所有匹配元素设置 background-color 和 font-size:

  1. $("p").css({"background-color":"yellow","font-size":"200%"});

 jQuery 尺寸

通过 jQuery,很容易处理元素和浏览器窗口的尺寸。

jQuery 提供多个处理尺寸的重要方法:

  • width()
  • height()
  • innerWidth()
  • innerHeight()
  • outerWidth()
  • outerHeight()

jQuery width() 和 height() 方法

width() 方法设置或返回元素的宽度(不包括内边距、边框或外边距)。

height() 方法设置或返回元素的高度(不包括内边距、边框或外边距)。

下面的例子返回指定的 <div> 元素的宽度和高度:

  1. $("button").click(function(){
  2. var txt="";
  3. txt+="div 的宽度是: " + $("#div1").width() + "</br>";
  4. txt+="div 的高度是: " + $("#div1").height();
  5. $("#div1").html(txt);
  6. });

jQuery innerWidth() 和 innerHeight() 方法

innerWidth() 方法返回元素的宽度(包括内边距)。

innerHeight() 方法返回元素的高度(包括内边距)。

下面的例子返回指定的 <div> 元素的 inner-width/height:

  1. $("button").click(function(){
  2. var txt="";
  3. txt+="div 宽度,包含内边距: " + $("#div1").innerWidth() + "</br>";
  4. txt+="div 高度,包含内边距: " + $("#div1").innerHeight();
  5. $("#div1").html(txt);
  6. });

jQuery outerWidth() 和 outerHeight() 方法

outerWidth() 方法返回元素的宽度(包括内边距和边框)。

outerHeight() 方法返回元素的高度(包括内边距和边框)。

下面的例子返回指定的 <div> 元素的 outer-width/height:

  1. $("button").click(function(){
  2. var txt="";
  3. txt+="div 宽度,包含内边距和边框: " + $("#div1").outerWidth() + "</br>";
  4. txt+="div 高度,包含内边距和边框: " + $("#div1").outerHeight();
  5. $("#div1").html(txt);
  6. });

 位置方法:

jQuery offset() 方法

返回 <p> 元素的偏移坐标:

  1. $("button").click(function(){
  2. var x=$("p").offset();
  3. alert("Top: " + x.top + " Left: " + x.left);
  4. });

定义和用法

offset() 方法设置或返回被选元素相对于文档的偏移坐标。

当用于返回偏移时: 
该方法返回第一个匹配元素的偏移坐标。它返回一个带有两个属性(以像素为单位的 top 和 left 位置)的对象。

当用于设置偏移时: 
该方法设置所有匹配元素的偏移坐标。

  1. //语法
  2. //返回偏移坐标:
  3. $(selector).offset()
  4. //设置偏移坐标:
  5. $(selector).offset({top:value,left:value})
  6. //使用函数设置偏移坐标:
  7. $(selector).offset(function(index,currentoffset))
参数 描述
{top:value,left:value} 当设置偏移时是必需的。规定以像素为单位的 top 和 left 坐标。

可能的值:

  • 名/值对,比如 {top:100,left:100}
  • 一个带有 top 和 left 的对象(实例
function(index,currentoffset) 可选。规定返回包含 top 和 left 坐标的对象的函数。

  • index - 返回集合中元素的 index 位置。
  • currentoffset - 返回被选元素的当前坐标。

 jQuery position() 方法

返回 <p> 元素的 top 和 left 位置:

  1. $("button").click(function(){
  2. x=$("p").position();
  3. alert("Top: " + x.top + " Left: " + x.left);
  4. });

定义和用法:

position() 方法返回第一个匹配元素的位置(相对于它的父元素)。

该方法返回一个带有两个属性(以像素为单位的 top 和 left 位置)的对象。

  1. //语法
  2. $(selector).position()

jQuery scrollTop() 方法

返回 <div> 元素的垂直滚动条位置:

  1. $("button").click(function(){
  2. alert($("div").scrollTop());
  3. });

定义和用法

scrollTop() 方法设置或返回被选元素的垂直滚动条位置。

提示:当滚动条位于最顶部时,位置是 0。

当用于返回位置时:
该方法返回第一个匹配元素的滚动条的垂直位置。

当用于设置位置时:
该方法设置所有匹配元素的滚动条的垂直位置。

  1. //语法
  2. //返回垂直滚动条位置:
  3. $(selector).scrollTop()
  4. //设置垂直滚动条位置:
  5. $(selector).scrollTop(position)

jQuery scrollLeft() 方法

返回 <div> 元素的水平滚动条位置:

  1. $("button").click(function(){
  2. alert($("div").scrollLeft());
  3. });

定义和用法

scrollLeft() 方法设置或返回被选元素的水平滚动条位置。

提示:当滚动条位于最左侧时,位置是 0。

当用于返回位置时:
该方法返回第一个匹配元素的滚动条的水平位置。

当用于设置位置时:
该方法设置所有匹配元素的滚动条的水平位置。

  1. //语法
  2. //返回水平滚动条位置:
  3. $(selector).scrollLeft()
  4. //设置水平滚动条位置:
  5. $(selector).scrollLeft(position)

【html、CSS、javascript-10】jquery-操作元素(属性CSS和文档处理)的更多相关文章

  1. 3 、操作元素 (属性 CSS 和 文档处理)

    3   操作元素-属性 CSS 和 文档处理  3.1 属性操作 $("p").text()    $("p").html()   $(":check ...

  2. jQuar总结10:jQuery操作元素的属性

    jQuery操作元素的属性 1 设置单个属性 //html <div></div> //js $('div').attr('id', 'box'); $('div').attr ...

  3. 使用jQuery操作元素属性

    在jQuery中,提供了attr函数来操作元素属性,具体如下: 函数名 说明 例子 attr(name) 取得第一个匹配元素的属性值. $("input").attr(" ...

  4. 转:jquery操作元素的css样式(获取、修改等等)

    //1.获取和设置样式 $("#tow").attr("class")获取ID为tow的class属性 $("#two").attr(&qu ...

  5. 使用jquery操作元素的css样式(获取、修改等等)

    //1.获取和设置样式 $("#tow").attr("class")获取ID为tow的class属性 $("#two").attr(&qu ...

  6. 使用jQuery操作元素的属性与样式

    本文学习如何使用jQuery获取和操作元素的属性和CSS样式. 元素属性和Dom属性 对于下面这样一个标签元素: <img id='img' src="1.jpg" alt= ...

  7. 《从零开始学习jQuery》:用jQuery操作元素的属性与样式

    元素属性和Dom属性简介 对于下面这样一个标签元素: <img id='img' src="1.jpg" alt='1' class="imgs"> ...

  8. jQuery操作元素的属性与样式

    本文学习如何使用jQuery获取和操作元素的属性和CSS样式. 元素属性和Dom属性 对于下面这样一个标签元素: <img id='img' src="1.jpg" alt= ...

  9. 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式

    本系列文章导航 从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式 一.摘要 本篇文章讲解如何使用jQuery获取和操作元素的属性和CSS样式. 其中DOM属性和元素属性的区分值得 ...

  10. jQuery入门(2)使用jQuery操作元素的属性与样式

    jQuery入门(1)jQuery中万能的选择器 jQuery入门(2)使用jQuery操作元素的属性与样式 jQuery入门(3)事件与事件对象 jQuery入门(4)jQuery中的Ajax()应 ...

随机推荐

  1. thinkphp3.2.3 nginx 连接mysql 报错 new PDO 异常

    在 php.ini 里重新指定mysql.sock 路径 pdo_mysql.default_socket=/Applications/XAMPP/xamppfiles/var/mysql/mysql ...

  2. Java怎样对一个属性设置set或get方法的快捷键

    具体步骤如下: 首页,在testApp.java 类中定义属性,例如:public Sting name; 其次,Alt+Shift+S,  选择Generate Getters and Setter ...

  3. [转]成为Java顶尖程序员 ,看这11本书就够了

    “学习的最好途径就是看书“,这是我自己学习并且小有了一定的积累之后的第一体会.个人认为看书有两点好处: 1.能出版出来的书一定是经过反复的思考.雕琢和审核的,因此从专业性的角度来说,一本好书的价值远超 ...

  4. ArrayBlockingQueue 和LinkedBlockQueue

    ArrayBlockingQueue ArrayBlockingQueue是Java多线程常用的线程安全的一个集合,基于数组实现,继承自AbstractQueue,实现了BlockingQueue和S ...

  5. jmeter遇到的问题之Windows读取jtl文件出错

    问题描述 ① 使用linux运行jmeter.jmx文件后生成result.jtl文件 jmeter -n -t /tmp/jmeter.jmx -l /tmp/testresult/result.j ...

  6. React中的this.props.children

    React this.props.children this.props对象的属性与组件的属性一一对应,但是有一个例外,就是this.props.children属性.它表示组件的所有子节点. var ...

  7. python随机数(转载)

    随机生成 0 到 1 之间的浮点数 random.random() 方法会返回 [0.0, 1.0) 之间的浮点数,注意,这是一个左闭右开的区间,随机数可能会是 0 但不可能为 1 . 随机生成 a ...

  8. SpringCloud学习笔记(三):Rest微服务构建案例工程模块

    需要具备的知识 1 springmvc+mybatis+mysql 2 Consumer消费者(Client)通过REST调用Provider提供者(Server)提供的服务 3 Maven的分包分模 ...

  9. Spring MVC(五)--控制器通过注解@RequestParam接受参数

    上一篇中提到,当前后端命名规则不一致时,需要通过注解@RequestParam接受参数,这个注解是作用在参数上.下面通过实例说明,场景如下: 在页面输入两个参数,控制器通过注解接受,并将接受到的数据渲 ...

  10. PAT甲级——A1009 Product of Polynomials

    This time, you are supposed to find A×B where A and B are two polynomials. Input Specification: Each ...