捕获内容和属性

1.DOM 操作

  获得内容 - text()、html() 以及 val()

    text() - 设置或返回所选元素的文本内容,如果不带值则是返回值,如果带值则是修改值,如:$('p').text('我要修改原来的文本');

    html() - 设置或返回所选元素的内容(包括 HTML 标记),如果不带值则是返回值,如果带值则是修改值,如:$('p').html("<b>Hello world!</b>");

    val() - 设置或返回表单字段的值,如果不带值则是返回值,如果带值则是修改值,如:$('input').val("修改input框的默认value值");

  获取属性 - attr() 或 prop()   

    对于 HTML 元素本身就带有的固有属性,在处理时,使用 prop 方法,如果带有属性值则是修改属性值,如果不带属性值则是返回属性值:如 $('a').attr('href' : 'www.guiqingyuang.com');

    对于 HTML 元素我们自己自定义的 DOM 属性,在处理时,使用 attr 方法。

  例:<a href="https://www.runoob.com" target="_self" class="btn">少时诵诗书</a>

    例子里 <a> 元素的 DOM 属性有: href、target 和 class,这些属性就是 <a> 元素本身就带有的属性,或者说在 IDE 里能够智能提示出的属性,这些就叫做固有属性。处理这些属性时,建议使用 prop 方法。

    1.如果有相应的属性,返回指定属性值。

    2.如果没有相应的属性,返回值是空字符串。

  例:<a href="#" id="link1" action="delete" rel="nofollow">删除</a>

    例子里 <a> 元素的 DOM 属性有: href、id 和 action,很明显,前两个是固有属性,而后面一个 action 属性是我们自己自定义上去的,<a> 元素本身是没有这个属性的。处理这些属性时,建议使用 attr 方法。

    attr 方法还支持同时修改多个属性,如:<a href="http://www.runoob.com" id="runoob">教程坎坎坷坷</a>

      $(document).ready(function(){

        $("button").click(function(){

          $("#runoob").attr({

            "href" : "http://www.runoob.com/jquery",

            "title" : "jQuery 教程"

          });

          // 通过修改的 title 值来修改链接名称

          title = $("#runoob").attr('title');

          $("#runoob").html(title);

         });

      });

    1.如果有相应的属性,返回指定属性值。

    2.如果没有相应的属性,返回值是 undefined。

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

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

  例:$(document).ready(function(){

      $("#btn1").click(function(){
        $("#test1").text(function(i,origText){ //这里function传两个参数,第一个是下标,第二个参数是原来的值 
          return "旧文本: " + origText + " 新文本: Hello world! (index: " + i + ")";
        });
      });

  例:$("#btn2").click(function(){

      $("#test2").html(function(i,origText){ //这里function传两个参数,第一个是下标,第二个参数是原来的值 
        return "旧 html: " + origText + " 新 html: Hello <b>world!</b> (index: " + i + ")";
      });
    });

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

  例:$(document).ready(function(){

      $("button").click(function(){

        $("#runoob").attr("href", function(i, origValue){  //这里function传两个参数,第一个是下标,第二个参数是原来的值

          return origValue + "/jquery";
        });
      });
    });

jQuery - 添加元素

  添加新的 HTML 内容

  添加新内容的四个 jQuery 方法:

  • append() - 在被选元素的结尾插入内容  如:  $("p").append("追加文本");
  • prepend() - 在被选元素的开头插入内容 如:  $("p").prepend("在开头追加文本");
  • after() - 在被选元素之后插入内容      如:  $("img").after("在后面添加文本");
  • before() - 在被选元素之前插入内容   如:  $("img").before("在前面添加文本");

  append() 和 prepend() 方法能够通过参数接收无限数量的新元素。可以通过 jQuery 来生成文本/HTML

  例:

    $('#lia').click(function(){
      var la1 = '<p>文本内容</p>'; // 使用 HTML 标签创建文本
      var la2 = $('<div></div>').text('文本内容222'); // 使用 jQuery 创建文本
      var la3 = document.createElement('h1');
       la3.innerHTML="我是通过dom创建的文本";
      $('span').prepend(la1, la2, la3);
    });

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

   例:$('#btnnn').click(function(){
      var laa1 = '<h2> 20120120 </h2>';
      var laa2 = $('<i></i>').text('我是使用jq方法添加的文本');
      var laa3 = document.createElement('button');
      laa3.innerHTML = '我是添加的按钮';
      var bsns = $('#huaaa').after(laa1, laa2, laa3);
      console.log('bsns==>', bsns);
     })

  删除元素

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

   remove() - 删除被选元素(及其子元素)  remove() 方法也可接受一个参数,允许您对被删元素进行过滤。

    例:$('#btna').click(function(){    //这里是移除所有带有listarr类的li标签和标签里面的内容

        $('#hua>li').remove('.listarr');

      })

    

    empty() - 从被选元素中删除子元素  

   例: $(function(){

      // remove 删除内容包括标签
      // $('#btna').click(function(){
        // $('.box-aa,p').remove();
      // });

      // empty(m铁) 删除内容,保留标签
      $('#btna').click(function(){
        $('.box-aa,p').empty();
       });
      })

 获取并设置 CSS 类 

  附:jquery中 first() 与  :first 的区别

    首先 jQuery 中默认有的方法是 .first(),而 :first 是 jQuery 选择器支持的语法 $('div:first')。

    实际上,.first() 方法就是 .eq(0) 的封装而已。

    比如 p:first 就是第一个P元素,p:last就是最后一个P元素(相对于整个页面)。除了这两个之外的怎么办?可以通过eq来遍历。如.eq(2)

   操作 CSS    

    addClass() - 向被选元素添加一个或多个类     

      $(function(){
        $('#btn').click(function(){
          $('.lia1,.lasta,p').addClass('on');
          $('.lia2,.listall').addClass('on1');
        });

        $('.lia1,.lasta,p').addClass('on1 on2');//添加多个类
      })

    removeClass() - 从被选元素删除一个或多个类

      例: $('.lia1,.lasta').removeClass('ass vvb df');

    toggleClass() - 对被选元素进行添加/删除类的切换操作

      例:$('.lia1,.lasta').toggleClass('ass vvb df');

    css() - 设置或返回样式属性     

       例: $('#btn').click(function(){
          // 获取css属性
          var aa = $('li').css('backgroundColor');
          console.log('aa==>', aa); //默认情况只获取第一个li的属性,要获取其他的需要使用伪类的nth-child()来获取
          var bb = $('li:nth-child(5)').css('backgroundColor');
          console.log('bb==>', bb);
          //但是nth-child()方法并不好,所以使用eq()来遍历,需要注意的是是从下标0开始算的,不是像nth-child()直接写位置的
          var cc = $('li').eq(3).css('backgroundColor');//这里eq(3)的实际位置是内容004的位置。
          console.log('cc==>', cc);

          //设置css属性
          $('li').eq(4).css({
            'backgroundColor':'#45ffff',
            'border':'solid 1px #f00'
          })
         })

  尺寸方法   

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

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

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

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

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

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

  需要注意的地方,设置了 box-sizing 后,width() 获取的是 css 设置的 width 减去 padding 和 border 的值。

  .test{width:100px;height:100px;padding:10px;border:10px;box-sizing:border-box;} 

  • width() 获取为: 60
  • innerWidth() 获取值为: 80
  • outWidth() 获取值为: 100

jquery快速入门(三)的更多相关文章

  1. jquery快速入门三

    事件 常用事件 click(function(){.......}) #触发或将函数绑定到指定元素的click事件 hover(function(){.....}) 当鼠标指针悬停在上面时触发.... ...

  2. day 48 jQuery快速入门

    jQuery快速入门   jQuery jQuery介绍 1.jQuery是一个轻量级的.兼容多浏览器的JavaScript库. 2.jQuery使用户能够更方便地处理HTML Document.Ev ...

  3. jQuery 快速入门教程

    内容目录 jQuery 入门 什么是jQuery 如何使用jQuery jQuery的运行原理 如何选择jQuery版本 ready() 准备就绪时执行代码 jQuery 核心:选取元素 使用jQue ...

  4. jquery快速入门(二)

    jQuery 效果 1.隐藏,显示 1.1显示 hide() 和隐藏 show() 语法:$(selector).hide(speed,callback); $(selector).show(spee ...

  5. jQuery快速入门专题

    jQuery入门专题 本人博客特点:最高重要等级为*****(五红星),依次减少代表重要性相对较低! 一.jQuery简介 jQuery 是一个 JavaScript的一个库,也就是说jQuery是基 ...

  6. jQuery简单入门(三)

    3.事件和动画 A. 事件 Aa. DOM加载 1.为什么使用jQuery加载DOM方法? 以javascript的window.onload()方法加载DOM的先决条件是:必须等待被请求页面的资源全 ...

  7. jquery快速入门(四)

    jQuery 遍历 向上遍历 DOM 树 parent() parent() 方法返回被选元素的直接父元素.该方法只会向上一级对 DOM 树进行遍历. parents() parents() 方法返回 ...

  8. jquery快速入门(一)

    一.jquery加载文档 jquery加载文档(也叫入口函数) $(document).ready(function(){ // 这里写 jQuery 代码... }); 简写方式: $(functi ...

  9. JQuery快速入门-简介

    一.什么是JQuery? jQuery是一个JavaScript库,它通过封装原生的JavaScript函数得到一整套定义好的方法.它的作者是John Resig,于2006年创建的一个开源项目,随着 ...

随机推荐

  1. 钉钉机器人zabbix报警

    首先在钉钉群聊里添加一个自定义的机器人 并复制webhook的内容 https://oapi.dingtalk.com/robot/send?access_token=37e23308d1b84eb4 ...

  2. python常见的报错提示

    在运行或编写一个程序时常会遇到错误异常,这时python会给你一个错误提示类名,告诉出现了什么样的问题(Python是面向对象语言,所以程序抛出的异常也是类).能很好的理解这些错误提示类名所代表的意思 ...

  3. SQL数据库的一些操作

    --以 MySQL为例 //登陆 mysql -u root -p //创建一个名为test_lib的数据库 CREATE DATABASE test_lib //删除一个名为test_lib的数据库 ...

  4. centos7 启动docker失败的解决

    控制端使用yum install docker安装完成docker后启动docker失败,出现以下信息: Job for docker.service failed because the contr ...

  5. python的知识统计笔记

    python的发展

  6. 重磅!!!微软发布.NET Core 2.2

    我们很高兴地宣布发布.NET Core 2.2.它包括对运行时的诊断改进,对ARM32 for Windows和Azure Active Directory for SQL Client的支持.此版本 ...

  7. asp.net core 系列之用户认证(authentication)

    ASP.NET Core 的 identity 是一种需要用户登录的会员系统,用户可以创建一个登录信息存储在 Identity 的的账号, 或者也可以使用第三方登录,支持的第三方登录包括:Facebo ...

  8. LeetCode算法题-Number of Lines To Write String(Java实现)

    这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...

  9. 抽象工厂模式--java代码实现

    抽象工厂模式 抽象工厂模式,对方法工厂模式进行抽象.世界各地都有自己的水果园,我们将这些水果园抽象为一个水果园接口,在中国.英国和美国都有水果园,种植不同的水果,比如苹果.香蕉和梨等.这里将苹果进行抽 ...

  10. 一文读懂Asp.net core 依赖注入(Dependency injection)

    一.什么是依赖注入 首先在Asp.net core中是支持依赖注入软件设计模式,或者说依赖注入是asp.net core的核心: 依赖注入(DI)和控制反转(IOC)基本是一个意思,因为说起来谁都离不 ...