最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 浅析 jQuery 功能

    正文概述 掘金(白杨233)   2020-12-19   353

    1、jQuery 获取元素

    jQuery的基本设计思想和主要用法,就是"选择某个网页元素,然后对其进行某种操作"。这是它区别于其他Javascript库的根本特点。

    jQuery是一个不需要加new的构造函数。 使用jQuery的第一步,往往就是将一个选择表达式,放进构造函数jQuery(),然后得到被选中的元素。

    window.$=window——因此使用$代为jQuery

    选择表达式可以是CSS选择器:

    $(document) //选择整个文档对象
    $('#Id') //选择ID为Id的网页元素
    $('div.myClass') // 选择class为myClass的div元素
    $('input[name=first]') // 选择name属性等于first的input元素
    

    也可以是jQuery特有的表达式:jQuery的扩展

    $('a:first') //选择网页中第一个a元素
    $('tr:odd') //选择表格的奇数行
    $('#myForm :input') // 选择表单中的input元素
    $('div:visible') //选择可见的div元素
    $('div:gt(2)') // 选择所有index(索引值)大于2的元素(index从0开始计算)
    $('div:animated') // 选择当前处于动画状态的div元素
    

    2、jQuery 的链式操作

    jQuery在最终选中网页元素以后,可以对它进行一系列操作,并且所有操作可以连接在一起,以链条的形式写出来。

    它的原理在于每一步的jQuery操作,返回的都是一个jQuery对象,所以不同操作可以连在一起。jQuery还提供了.end()方法,使得结果集可以后退一步。

    $('div') //找到div元素
       .find('h3') //选择其中的h3元素
       .eq(2)  //选择第3个h3元素
       .html('Hello')  //将它的内容改为Hello
       .end() //退回到选中所有的h3元素的那一步
       .eq(0) //选中第一个h3元素
       .html('World'); //将它的内容改为World
    

    3、元素的创建、复制和删除

    (1)元素的创建

    创建新元素的方法非常简单,只要把新元素直接传入jQuery的构造函数就行了:

    $('<p>Hello</p>');
    $('<li class="new">new list item</li>');
    $('ul').append('<li>list item</li>');
    //apend在每个匹配元素里面的末尾处插入参数内容
    

    (2)元素的删除

    .detach()    //从DOM中去掉所有匹配的元素
    .remove()      //将匹配元素集合从DOM中删除。(注:同时移除元素上的事件及 jQuery 数据。)
    .empty()    //这个方法不仅移除子元素(和其他后代元素),同样移除元素里的文本
    

    区别

    • .remove().detach()可以删除元素本身,前者不保留被删除元素的事件,后者保留,有利于重新插入文档时使用。
    • .empty() 删除子元素但是不删除元素本身,还会删除元素本身的文本,因为这些文本会被当做子节点删除。

    (3)复制

    .clone() —— 深拷贝。

    4、元素的插入

    元素的插入分为:(1)插入现有元素内;(2)插入现有元素外。

    (1)插入现有元素内:

    • .append().appendTo()——作为最后一个子元素插入。

    两者实现同样的功能。主要的不同是语法——内容和目标的位置不同。

    例如
    <h2>Greetings</h2>
    <div class="container">
      <div class="inner">Hello</div>
      <div class="inner">Goodbye</div>
    </div>
    使用:
    $('.inner').append('<p>Test</p>') 
    $('<p>Test</p>').appendTo('.inner') 
    均得到:
    <div class="inner">Hello<p>Test</p>  </div>
    <div class="inner">Goodbye<p>Test</p> </div>
    
    • .prepend().prependTo()——作为第一个子元素插入。同样二者之间实现的功能相同,语法不同。
    $('.inner').prepend('<p>Test</p>');
    $('<p>Test</p>').prependTo('.inner');
    均得到
    <div class="inner">
        <p>Test</p>
        Hello
    </div>
    

    (2)插入现有元素外

    • .insertAfter().after()两者实现同样的功能。主要的不同是语法——特别是(插入)内容和目标的位置。
    例如
    <div class="container">
      <h2>Greetings</h2>
      <div class="inner">Hello</div>
    </div>
    使用:
    $('<p>Test</p>').insertAfter('.inner');
    $('.inner').after('<p>Test</p>');
    均得到:
    <div class="inner">Hello</div>
    <p>Test</p>
    
    • .before().insertBefore()同理:
    $('.inner').before('<p>Test</p>');
    $('<p>Test</p>').insertBefore('.inner');
    均得到:
    <p>Test</p>
    <div class="inner">Hello</div>
    

    5、获取和设置属性

    常用方法概述:

    • .attr()——获取第一个元素的属性值。
    • .removeAttr()——元素集合中的每个元素中移除一个属性。
    • .val()——获取元素集合中第一个元素的当前值,主要用于获取表单元素的值。
    • .addClass()——增加样式名,样式名多个用空格隔开(这个方法不会替换一个样式类名。它只是简单的添加一个样式类名到元素上)。
    • .css()——获取和设置第一个元素的CSS属性。
    • .removeClass()——多个样式名需用空格隔开。
    • .toggleClass()——如果在元素集合中的每个元素上存在该样式类就会被移除;如果某个元素没有就会加上这个样式类。
    • .html()——取出或设置html内容。
    • .text()——取出或设置text内容。
    • .offset()——返回元素相对于文档的坐标。
    • .position()——取得元素相对于父元素的偏移位置。

    参考文档:jQuery 中文文档,阮一峰的《jQuery设计思想》。

    起源地下载网 » 浅析 jQuery 功能

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元