初学jQuery知识梳理

绪论

jQuery是一套跨浏览器的类库, 集成了JavaScript/DOM/BOM的类库,支持链市编程,大大地简化了JavaScript与HTML之间的操作.完整详细的API文档可以看这里jQuery中文文档.下面我就主要归纳一下自己学到的且常用的知识点.
其他知识

jQuery目前有1,2,3版本系列:
1.x  (兼容性最好)
2.x
3.x  (功能最齐全)
    1.x和2.x版本系列在有些的jQuery的API处理上并不彻底.例如给HTML的勾选框(checkbox)添加属性(attr)"checked='checked'"时,有的时候便会勾选不上.

一.查看元素

在使用DOM来查找HTMl的标签元素时,使用的常用属性大概在10个左右,而且不能直接找到标签中的自定义属性.总的来说,相比于jQuery,DOM找到标签元素的效率更低.

选择器(直接找到某个或者某类标签)
1.id:

    例:
        $('#id')      //根据id属性寻找标签.

2.class:

      例:$('.class')     //根据class属性寻找标签

3.标签

例子1:
                <div id='i10' class='c1'>
                    <a>f</a>
                    <a>f</a>
                </div>
                <div class='c1'>
                    <a>f</a>
                </div>
                <div class='c1'>
                    <div class='c2'> </div>
                </div>
$('a')        //找到所有a标签

4.组合

                <div id='i10' class='c1'>
                    <a>f</a>
                    <a>f</a>
                </div>
                <div class='c1'>
                    <a>f</a>
                </div>
                <div class='c1'>
                    <div class='c2'> </div>
                </div>
$('a, .c2, #i10')     //组合查找多个标签

5.层级

$('#i10 a')        //查找id为i10的标签中所有孩子标签中的a标签
$('#i0>a')         //查找id为i10的标签的儿子标签中的a标签

6.基本

:first      //标签中的第一个标签元素。
:last      //标签中的最后一个标签元素。
:eq()   //根据索引值找到标签元素。例:$('#i1 a:eq(0)')   //找到id为'i1'的标签下的孩子a标签中的第一个

7.属性

$('[alex]')       //寻找具有alex属性的所有标签
$('[alex="123"]')      //寻找alex属性等于123的标签
$(':text')       //寻找属性tpye为text的input标签

8.筛选

            例:<div>
                <a>asdf</a>
                <a>asdf</a>
                <a id='i1'>asdf</a>
                <a>asdf</a>
                <a id='i2'>asdf</a>
                <a>asdf</a>
              </div>
            $('#i1').next()        //下一个标签
            $('#i1').nextAll()  //当前标签以后的所有兄弟标签
            $('#i1').nextUntil('#i2')  //从当前标签到属性id为‘i2’的标签之间的标签(往后寻找)

            $('#i1').prev()        //上一个标签
            $('#i1').prevAll()  //当前标签以前的所有兄弟标签
            $('#i1').prevUntil('#i2')  //从当前标签到属性id为‘i2’的标签之间的标签(往前寻找)


            $('#i1').parent()  //父标签
            $('#i1').parents()  //所有的父亲和祖父标签
            $('#i1').parentsUntil()  

            $('#i1').children()    //子标签
            $('#i1').siblings()    //所有的兄弟标签
            $('#i1').find()        //在所有还在标签中寻找

二.操作元素

1.文本操作:

            $(..).text()           # 获取文本内容
            $(..).text(“<a>1</a>”) # 设置文本内容

            $(..).html()       //获取文本内容(连标签一起)
            $(..).html("<a>1</a>") //设置文本内容(连标签一起)

            $(..).val()        //具有value属性标签的才能使用
            $(..).val(..)

2.样式操作

            addClass     //添加指定class属性值
            removeClass  //移除指定class属性值
            toggleClass  //当指定class属性值存在时,该方法将其移除;当指定class属性值不存在时,该方法将其添加.

3.属性操作

            # 专门用于做自定义属性
            $(..).attr('n')        //获取属性值
            $(..).attr('n','v')    //新增或重新设置属性值

4.css处理

$('t1').css('样式名称', '样式值')

5.文档处理

            append   //向每个匹配的元素内部(孩子)追加内容。
            prepend  //向每个匹配的元素内部(孩子)前置内容
            after    //在每个匹配的元素之后(兄弟)插入内容。
            before   //在每个匹配的元素之前(兄弟)插入内容。

            remove   //从DOM中删除所有匹配的元素。这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。但除了这个元素本身得以保留之外,其他的比如绑定的事件,附加的数据等都会被移除。
            empty   //删除匹配的元素集合中所有的子节点。(包括自身的文本内容)

            clone   //克隆匹配的DOM元素并且选中这些克隆的副本

其他

1.prop

            # 专门用于chekbox,radio
            $(..).prop('checked')
            $(..).prop('checked', true)

2.索引

            #index 获取索引位置
            $(..).index()

3.位置

        $(window).scrollTop()  //获取最外层页面的滚动条位置
        $(window).scrollTop(0) //设置最外层页面的滚动条位置
        scrollLeft([val])      //获取匹配元素相对滚动条左侧的偏移。

        offset().left                 //获取指定标签在html中的坐标
        offset().top                  //获取指定标签在html中的坐标
        offset({ top: 10, left: 30 })  //设置指定标签的位置.

        position()                    //获取指定标签相对父标签(relative)标签的坐标

5.高度

        $('i1').height()           # 获取标签的高度(纯高度)
        $('i1').innerHeight()      # 纯高度
        $('i1').outerHeight()      # 获取上下边框宽度 + 纯高度
        $('i1').outerHeight(true)  # 获取上下边框边框 + 纯高度

        # 纯高度,边框,外边距,内边距

6.事件的绑定方式

                $('.c1').click()

                $('.c1').bind('click',function(){})
                $('.c1').unbind('click',function(){    })

                *******************
                $('.c').delegate('a', 'click', function(){})   //委托:立即绑定立即执行。
                $('.c').undelegate('a', 'click', function(){})

                $('.c1').on('click', function(){})
                $('.c1').off('click', function(){})

7.扩展

    $.extend        $.方法
    $.fn.extend     $(..).方法

小技巧

1.当一个标签绑定多个事件,阻止后面默认事件发生(可以用于表单验证)

                例.DOM:<a onclick="return a()"></a>
                        function a(){
                            return false
                            }
                    jQuery:$("a").click(function(){
                        return false
                        })
2.当页面框架加载完成之后(不需要等页面所有元素完全加载完毕后),自动执行JavaScript
            $(function(){
                $(...)
            })
3.解决多个js文件引入时造成的全局变量重名冲突.
    (function(){
            var status = 1;
            // 封装变量
        })(jQuery)

如有错误知识点, 希望大家能给我指出, 我会认真改过来(如果真错了)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值