美文网首页
十七、初识jquery

十七、初识jquery

作者: 风中丶凌乱 | 来源:发表于2018-09-18 23:43 被阅读0次

    jquery加载

    1. 首先引入外部jquery文件
    <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
    
    1. alert($) 弹出function (a,b){return new n.fn.init(a,b)}表示JQuery已经引进来了,这是它的一个构造函数

    将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。

    如果想再写其他jq代码,需要再写一个script标签,然后在这个标签中写代码。

    js代码写法:

    windows.onload = function(){
            var oDiv = document.getElementById('div');
            alert(oDiv.innerHTML);
    }
    

    jquery的完整写法
    比上面的JS写法先弹出,因为window.onload是把页面加载、渲染完毕之后才弹出,而ready()是把所有页面的节点加载之后就弹出了,不用等渲染了。

    $(document).ready(function(){
            var $div = $('div');
            alert('jQuery:' + $div.html());//jQuery:这是一个div元素
    })
    

    简写方式

    $function(){
            var $div = $('div')//和CSS样式写法一样
             //html方法相当于原生JS的innerHTML
            alert($div.html() + 'jQuery');
    }
    

    jquery选择器

    jquery用法思想一
    选择某个网页元素,然后对它进行某种操作

    jquery选择器

    jquery选择器可以快速地选择元素,选择规则和css样式相同,使用length属性判断是否选择成功。

    $(document) //选择整个文档对象
    $('li') //选择所有的li元素
    $('#myId') //选择id为myId的网页元素
    $('.myClass') // 选择class为myClass的元素
    $('input[name=first]') // 选择name属性等于first的input元素
    $('#ul1 li span') //选择id为为ul1元素下的所有li下的span元素
    

    对选择集进行修饰过滤(类似CSS伪类)

    $('#ul1 li:first') //选择id为ul1元素下的第一个li
    $('#ul1 li:odd') //选择id为ul1元素下的li的奇数行
    $('#ul1 li:eq(2)') //选择id为ul1元素下的第3个li
    $('#ul1 li:gt(2)') // 选择id为ul1元素下的前三个之后的li
    $('#myForm :input') // 选择表单中的input元素
    $('div:visible') //选择可见的div元素
    

    对选择集进行函数过滤

    $('div').has('p'); // 选择包含p元素的div元素
    $('div').not('.myClass'); //选择class不等于myClass的div元素
    $('div').filter('.myClass'); //选择class等于myClass的div元素
    $('div').first(); //选择第1个div元素
    $('div').eq(5); //选择第6个div元素
    

    选择集转移

    $('div').prev('p'); //选择div元素前面的第一个p元素
    $('div').next('p'); //选择div元素后面的第一个p元素
    $('div').closest('form'); //选择离div最近的那个form父元素
    $('div').parent(); //选择div的父元素
    $('div').children(); //选择div的所有子元素
    $('div').siblings(); //选择div的同级元素
    $('div').find('.myClass'); //选择div内的class等于myClass的元素
    

    例子:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>选择集转移</title>
        <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
        <script type="text/javascript">
            $(function(){
                //prev()是同级的上一个元素,prevAll()是同级的上面所有的元素
                //next()是同级的下一个元素,nextAll()是同级的下面所有的元素
    
                //修改#div1的下一个元素的样式
                $('#div1').next().css({color: 'red'});
    
                //修改#div1的下面所有p标签设置样式
                $('#div1').nextAll('p').css({color: 'red'});
    
                //选择上一级的父元素
                /*$('#span01').parent().css({
                    width:'100px',
                    height:'100px',
                    background:'gold'
                })*/
    
                //获取祖级用$('#span02').parent().parent()不可取,可用closest('div')获取离span02最近的div
                //closest可以选择离自己最近的元素,元素可以是父级,也可以是子集
                $('#span01').closest('div').css({
                    width:'200px',
                    height:'200px',
                    background:'pink'
                })
    
                /*
                $('.list li')与$('.list').children()的区别:
                    原始的选择集不一样
                    $('.list li')不能通过end()回到父级
                    $('.list').children()可以通过end()回到父级
                */
                $('.list').children().css({
                    background:'gold',
                    height:'30px',
                    marginBottom:'10px'
                }).end().css({
                    background:'green'
                })
    
                //eq(2)是选择索引等于2的第三个li,siblings()表示除第三个之外的其它兄弟li
                $('.list2 li:eq(2)').css({background:'gold'}).siblings().css({background:'green'});
    
                //find()是选择div内的class等于link1的元素
                $('#div2').find('.link1').css({color:'red'});
            })
        </script>
    </head>
    <body>
        <div id="div1">这是一个div元素</div>
        <div>这是第二个div元素</div>
        <p>这是一个p元素</p>
    
        <div>
            <p>
                <a href="#">腾讯网</a>
                <span id="span01">span元素</span>
            </p>
        </div>
    
        <ul class="list">
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
            <li>6</li>
            <li>7</li>
            <li>8</li>
        </ul>
    
        <ul class="list2">
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
        </ul>
    
        <div id="div2">
            <p>
                <a href="#" class="link1">腾讯网</a>
            </p>
        </div>
    </body>
    </html>
    

    相关文章

      网友评论

          本文标题:十七、初识jquery

          本文链接:https://www.haomeiwen.com/subject/llzvnftx.html