zoukankan      html  css  js  c++  java
  • jQuery基础总结

    转自:http://www.cnblogs.com/springsnow/archive/2010/06/08/1753901.html

    1 :eq()和nth-child()

    看下面代码:
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $("#selected-plays > li:eq(1)").addClass("a");
    //等价于

    $("#selected-plays > li:nth-child(2)").addClass("a");

    //注意:js数组是从 0 开始的,所以eq(1)是取第二个元素。
    //而css选择器:nth-child()是从 1 开始的, 所以要选择第二个元素, 得使用 :nth-child(2) ,而不是:nth-child(1)。
    })
    </SCRIPT>

    2,:odd 和 :even

    :odd : 奇数行 
    :even : 偶数行
    新手经常会说,好像跟我们做的相反?
    其实与 :eq() 选择器一样, 下标都是从 0开始的,
    也就是 表格的第一行 编号是 0 (偶数);
    第二行 编号是 1 (奇数);以此类推。。。

    3, $("tr:odd").addClass()

    可以写成 $("tr").filter(":odd").addClass()

    4,$('td:contains("cssrain")')

    //取得 包含 字符串 cssrain 的所有td

    5,jquery 转 dom :

    $("td").get(0).tagName 或 $("td")[0].tagName

    6,load():

    jquery中的load()有2层意思,
    第一层 意思 可以等价于 dom中 window.onload
    第二层 意思 可以load(url )。

    7:ready简写:

    1;
    $(document).ready(function(){ 
    //do something
    })
    2;
    $().ready(function(){ 
    //do something
    })
    3;
    $(function(){ 
    //do something
    })

    8,事件冒泡:


    正常的来说:点击B 会触发a的click。
    如果我们不想触发A,可以用stopPropagation() 阻止冒泡.
    具体例子:
    <div id="a">aaaaaaa
    <div id="b">bbbbbbbb</div>
    aaaaaa</div>
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#a').click(function(){
    alert("A")
    })
    $('#b').click(function(e){
    alert("B")
    e.stopPropagation();//阻止冒泡, 从来不输出 “A" 。 可以去掉 ,试试对比效果。
    })
    })
    </SCRIPT>

    9, hide()show()会记住上一次的dipslay状态

    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').toggle(function(){
    $('#a').hide();//display : none ,记住display 为 inline
    $('#b').hide();//display : none ,记住display 为 block
    },function(){
    $('#a').show(); //display : inline
    $('#b').show(); //display : block
    })
    })
    </SCRIPT>
    <DIV id="a" style="display:inline;">a</div>
    <DIV id="b" style="display:block;">b</div>
    <input type="button" id="test" value="test" />

    10, hide() show()加时间参数


    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').toggle(function(){
    $('#a').hide(500);//display : none
    $('#b').hide(500);//display : none
    },function(){
    $('#a').show(500); //display : inline
    $('#b').show(500); //display : block
    })
    })
    </SCRIPT>
    <DIV id="a" style="display:inline;">a</div>
    <DIV id="b" style="display:block;">b</div>
    <input type="button" id="test" value="test" />

    11,效果:


    show(), hide()会同时修改多个样式属性 : 高度,宽度和不透明度。
    fadeIn() fadeOut() : 不透明度
    fadeTo() : 不透明度
    slideDown() , slideUp() :高度

    如果都不能满意,只能用animate()了
    animate()提供了更为强大的,复杂的效果。

    12,animate() :

    之前 .show('slow'); // slow代表的是0.6秒内同时改变高度,宽度和透明度 。 如果用时间表示是 600 ;=== .show(600);
    那么我们再来看看 animate()

    animate({heigth : 'slow' ,width : 'slow' } , 'slow' ) 
    这里之所以可以 height : 'slow' 其实就跟 .show('slow') 类似,当然他前面规定了height 。。

    13,做动画之前 先确定位置。


    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#a').css("position","absolute");//如果把这句去掉,动画就没了
    /*
    在使用.animate之前,请先把位置确定,不管你是用的 absolute 还是relative
    总之要设置其中的一种,因为所有的块级元素默认是static。
    其实是跟css有关。
    */
    $('#test').click(function(){
    $('#a').animate({ left : '300' } , 'slow' )
    })
    })
    </SCRIPT>
    <DIV id="a" >a</div>
    <input type="button" id="test" value="test" />

    14,width()和css('width')

    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    var t1 = $('#a').width();
    var t2 = $('#a').css('width');
    alert( t1 ); //200 , 不带单位
    alert( t2 ); //200px , 带单位
    alert( parseInt(t2) ) //200 , 不带单位
    })
    })
    </SCRIPT>
    <DIV id="a" style="200px">a</div>
    <input type="button" id="test" value="test" />

    15:animate()做动画效果时,动画执行的顺序。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    $('#a').animate({left : "300px" } , "slow" )
    .animate({ top : "300px" } , "slow" );

    })
    })
    </SCRIPT>
    <DIV id="a" style="position:absolute;10px;height:10px;">a</div>
    <input type="button" id="test" value="test" />
    //发生上面是按照顺序来执行的。先改变left,然后再改变top

    对比:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="http://www.cssrain.cn/demo/JQuery+API/jquery-1[1].2.1.pack.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    $('#a').animate({left : "300px" , top : "300px"} , "slow" )
    })
    })
    </SCRIPT>
    <DIV id="a" style="position:absolute;10px;height:10px;">a</div>
    <input type="button" id="test" value="test" />
    //发生上面是一起执行的,也就是 left和top 一起改变。

    区别知道了吧。

    16,同理,我们再看一个例子:


    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    $('#a').animate({left : "300px" } , "slow" )
    .fadeTo('slow',0.2)
    .animate({ top : "300px" } , "slow" )
    .fadeTo('slow',1);

    //排队效果会一个个执行。
    })
    })
    </SCRIPT>
    <DIV id="a" style="position:absolute;40px;height:40px;top:100px;background:red;">a</div>
    <input type="button" id="test" value="test" />
    //当animate()跟其他动画效果执行的时候,也是排队执行的。也就是一个个来。

    对比:css()
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    $('#a').animate({left : "300px" } , "slow" )
    .fadeTo('slow',0.2)
    .animate({ top : "300px" } , "slow" )
    .fadeTo('slow',1)
    .css("backgroundColor","#000");

    //虽然css写在最后,但点击一开始就会执行。
    //排队效果并不适合 .css()

    })
    })
    </SCRIPT>
    <DIV id="a" style="position:absolute;40px;height:40px;top:100px;background:red;">a</div>
    <input type="button" id="test" value="test" />

    解决:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    $('#test').click(function(){
    $('#a').animate({left : "300px" } , "slow" )
    .fadeTo('slow',0.2)
    .animate({ top : "300px" } , "slow" )
    .fadeTo('slow',1 ,function(){
    $(this).css("backgroundColor","#000");
    })

    //我们可以把他写在 最后一个效果的 回调函数里。
    })
    })
    </SCRIPT>
    <DIV id="a" style="position:absolute;40px;height:40px;top:100px;background:red;">a</div>
    <input type="button" id="test" value="test" />

    总结:
    当在animate 中以多个属性的方式应用时, 效果是同时发生的。
    当以 连续方式 应用时, 是按顺序来的。
    非效果方法,比如.css()方式不是按照顺序来的,解决方法是 放在回调函数里。

    17, 做一个实例 : 段落


    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
    <title>DOM Manipulation</title>
    <script src="jquery.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    // $('<a href="#top">回到顶部</a>').insertAfter('div.chapter p');//每个段落后面添加 超链接
    $('<a href="#top">回到顶部</a>').insertAfter('div.chapter p:gt(2)');//(除掉前3个 )每个段落后面添加 超链接
    $('<a name="top"></a>').prependTo('body');//在body后的开始位置 添加 超链接。
    })
    </SCRIPT>
    </head>
    <body>
    <h1 id="excerpt">Demo</h1>
    <div class="chapter">
    <p>段落1段落1段落1段落1<br/><br/><br/><br/><br/><br/></p>

    <p>段落2段落2段落2段落2<br/><br/><br/><br/><br/><br/></p>

    <p>段落3段落3段落3段落3<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落4段落4段落4段落4<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落5段落5段落5段落5<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落6段落6段落6段落6<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落7段落7段落7段落7<br/><br/><br/><br/><br/><br/><br/></p>
    </body>
    </html>

    改进:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
    <title>DOM Manipulation</title>
    <script src="http://www.cssrain.cn/demo/JQuery+API/jquery-1[1].2.1.pack.js" type="text/javascript"></script>
    <SCRIPT LANGUAGE="JavaScript">
    $(function(){
    // $('<a href="#top">回到顶部</a>').insertAfter('div.chapter p');//每个段落后面添加 超链接
    $('<a href="#top">回到顶部</a>').insertAfter('div.chapter p:gt(2)');//(除掉前3个 )每个段落后面添加 超链接
    $('<a name="top"></a>').prependTo('body');//在body后的开始位置 添加 超链接。

    $('div.chapter p').each(function(index){
    $(this).attr("id","node_"+(index+1) );
    //瞄点:在 标签a 上可以用name
    //在标签p上 我用name不可以,只能用id
    })

    var k ="";
    $('div.chapter p').each(function(index){
    k += "<a href='#node_"+(index+1)+"'>段落"+(index+1)+"</a> ";
    })
    $(k).insertBefore('.chapter');//在body后的开始位置 添加 超链接。
    //用prependTo()的时候, 发现k的内容 被倒置了。我晕。。。
    //所以 改用 insertBefore()、
    })
    </SCRIPT>
    </head>
    <body>
    <h1 id="excerpt">Demo</h1>
    <div class="chapter">
    <p>段落1段落1段落1段落1<br/><br/><br/><br/><br/><br/></p>

    <p>段落2段落2段落2段落2<br/><br/><br/><br/><br/><br/></p>

    <p>段落3段落3段落3段落3<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落4段落4段落4段落4<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落5段落5段落5段落5<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落6段落6段落6段落6<br/><br/><br/><br/><br/><br/><br/></p>

    <p>段落7段落7段落7段落7<br/><br/><br/><br/><br/><br/><br/></p>
    </body>
    </html>

    18,包装元素 : wrap():

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
        <title>DOM Manipulation</title>

        <script src="jqurey.js" type="text/javascript"></script>

        <script language="JavaScript">
            $(function() {
                $("p").wrap("<div class='chapter'></div>");
            })
        </script>

    </head>
    <body>
        <p>
            段落1段落1段落1段落1</p>
        <p>
            段落2段落2段落2段落2</p>
    </body>
    </html>
    <!--
    结果为:
    <div class="chapter">
    <p>
    段落1段落1段落1段落1
    </p>
    </div>

    <div class="chapter">
    <p>
    段落2段落2段落2段落2
    </p>
    </div>

    而不是:
    <div class="chapter">
    <p>
    段落1段落1段落1段落1
    </p>
    <p>
    段落2段落2段落2段落2
    </p>
    </div>

    -->

    19, 关于clone:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
        <title>DOM Manipulation</title>

        <script src="jquery.js" type="text/javascript"></script>

        <script language="JavaScript">
            $(function() {
                $("p").bind("click", function() {
                    alert("cssrain test:");
                })
                $("p").clone(true).appendTo("body");
                $("p").clone(false).appendTo("body");
                //我们发现 clone(true) 会连带绑定的事件一起复制,
                //false只复制元素,而绑定的事件已经被它扔掉。
                $("p").clone().appendTo("body"); //默认是 false
                /*
                这点 jquery的clone()跟dom里的clone有点区别了。
                如果想实现dom 里的clone()
                可以这么做;
                $("p").clone(true).empty().appendTo("body");
                */
            })
        </script>

    </head>
    <body>
        <p>
            段落1段落1段落1段落1</p>
    </body>
    </html>

    20, DOM操作总结:


    创建节点:
    直接 $("<p>cssrain</p>")

    复制节点:
    .clone()

    插入节点:
    .append()
    .appendTo()
    .prepend()
    .prependTo()
    .after()
    .insertAfter()
    .before()
    .insertBefore()

    删除节点:
    .remove()

    清空节点:
    .empty()

    包装节点:
    .wrap()

    设置属性
    .attr()

    删除属性
    .removeAttr()

    基本跟javascript中的DOM操作一样,clone()稍微不一样,前面例子说过区别了。。

  • 相关阅读:
    设计模式
    Lambda表达式
    网络通信
    排序
    可变参数
    反弹shell学习总结
    Apache Flink任意Jar包上传导致远程代码执行漏洞复现
    定时执行rsync同步数据以及mysql备份
    python练习
    django 模型生成sql(多对多)
  • 原文地址:https://www.cnblogs.com/exe19/p/5357901.html
Copyright © 2011-2022 走看看