1、$(document).ready()方法和window.onload差分法

为页元件的正确操作,我们需要把操作元件JS编写的代码$(document).ready()(Jquery)或window.onload(普通JS)中。$(document).ready()(这样的写法实际上是/把dom对象document转换成了jQuery对象,然后注冊ready()事件)一般我们能够简化为

$(function(){

........jquery代码...........

});

以下介绍一些它们的差别:

  1. 运行时机

    window.onload方法是在网页中的全部的元素(包含元素的全部关联文件)都全然载入到浏览器之后才运行。而通过jQuery中的$(document).ready()方法仅仅要在DOM全然就绪时,就能够调用了。比方一张图片仅仅要<img>标签完毕,不用等这个图片载入完毕,就能够设置图片的宽高的属性或样式等。

  2. $(document).ready()方法能够多次使用而注冊不同的事件处理程序,而window.onload一次仅仅能保存对一个函数的引用。多次绑定函数仅仅会覆盖前面的函数。
  3. 2、$.map函数(obj, fn)和$.each(obj, fn)函数。

    • obj (Object): 要反复迭代的对象或数组
    • fn (Function): 要在每一个对象中运行的函数

    $.each(obj, fn(key,value))用于遍历键值对集合。假设是普通数组。则键为下标index

    var dict = { 'person1': '人类1', 'person2': '人类2' };
    var result = $.each(dict, function (k,v) {
    alert(k+"==="+v);//结果是分别弹出person1===人类1。person2====人类2
    });
     

    $.map函数(obj, fn(value,index))

  4. var arrInt = [1, 3, 5, 7, 9]; 
    
    var result = $.map(arrInt, function (val, index) { 
    
    //通过实际观察,发现。传递的函数有两个參数。当中第一个參数表示遍历的数组中的元素的值,第二个表示元素的索引 
    
    return val * 2; 
    
    }); 
    
    alert(result); //结果是2,6,10,14,18

    3、Dom和Jquery对象转换

    dom对象转为jquery对象,var div=document.getElementById();var jqdom=$(div),这样就能够用jquery的一些成员,如text

    jquery对象转为dom对象:var domobj=jqdom[0];这样又能够用dom的一些成员了,如innnerText

    4、选择器:

    标签选择器:$('p');

    ID选择器:$('#p1');

    类选择器:$('.a')

    组合选择器:$('#btn,#p1,span')

    标签+类选择器:$('p.a')。

    层次选择器:$('div p');

    $('div >p')div下直接子元素;

    $('div ~ p')在div后。搜索全部p兄弟,等于$('div').nextAll('p')。

    $('div +p')div后仅仅找紧挨着的第一个p元素兄弟,等于$('div').next('p')。

    5、隐式迭代:$('p').text('');无需循环便可设置全部p标签文字

    6、链式编程:

    用链式编程时。须要注意next(),nextAll返回的已经不是原来的元素。也能够用end()恢复前一次的状态。如$(this).prevAll().css('').end().siblings();

    text()、html()、val()这些方法用来设置值的时候能够链式编程,可是获取内容的时候不能链式编程,由于获取值的时候。返回值内容变了。

    【并非不论什么时候都能链式编程,当返回值不是原来的对象时,就不能链式编程了。】

    $('p').text('我们都是p!').css('border', '5px solid yellow').click(function () {
    alert($(this).text());
    });

    7、设置与获取

    设置css:$(this).css({'width':'100px','border':'1px'});获取css中某个属性var width=$(this).css('width')

    设置attr:$(this).attr('width','100px'),获取attr某个属性:var width=$(this).attr('width')

    设置text:$(this).text('text1'),获取text,var txt=$(this).text()

    设置val:$(this).val('text1'),获取text,var val=$(this).val()

    8、过滤器:

    $('p:first')第一个p元素,等于$('p').first()

    $('p':last)最后一个p元素,等于$('p').last();

    $('p:eq(2)')依据索引

    $('p:even')选取全部偶数个p

    $('odd)选取全部奇数个p

    $('p:gt(index)')大于索引

    $('p:lt(index)')小于索引

    $('header')选取全部h1-h6元素

    $('input:not(.myclass)')选取样式名不是myclass

    过滤器练习:

    过滤器练习

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title></title>
    <script src="scripts/jquery-1.8.2.js" type="text/javascript"></script>
    <script type="text/javascript">
    $(function () {
    $('#table1 tr:first').css('font-size', '30px');
    $('#table1 tr:last').css('color', 'red');
    $('#table1 tr:gt(0):lt(3)').css('fontSize', '28px');
    $('#table1 tr:odd').css('backgroundColor', 'red');
    });
    </script>
    </head>
    <body>
    <table id="table1" border="1">
    <tr>
    <td>
    姓名
    </td>
    <td>
    成绩
    </td>
    </tr>
    <tr>
    <td>
    tom
    </td>
    <td>
    100
    </td>
    </tr>
    <tr>
    <td>
    jim
    </td>
    <td>
    99
    </td>
    </tr>
    <tr>
    <td>
    john
    </td>
    <td>
    98
    </td>
    </tr>
    <tr>
    <td>
    jason
    </td>
    <td>
    97
    </td>
    </tr>
    <tr>
    <td>
    aaa
    </td>
    <td>
    97
    </td>
    </tr>
    <tr>
    <td>
    平均分
    </td>
    <td>
    98
    </td>
    </tr>
    </table>
    </body>
    </html>

    9、Jquery效果:

    animate() 对被选元素应用“自己定义”的动画
    clearQueue() 对被选元素移除全部排队的函数(仍未执行的)
    fadeIn() 逐渐改变被选元素的不透明度。从隐藏到可见
    fadeOut() 逐渐改变被选元素的不透明度,从可见到隐藏
    fadeTo() 把被选元素逐渐改变至给定的不透明度
    hide() 隐藏被选的元素
    show() 显示被选的元素
    slideDown() 通过调整高度来滑动显示被选元素
    slideToggle() 对被选元素进行滑动隐藏和滑动显示的切换
    slideUp() 通过调整高度来滑动隐藏被选元素
    stop() 停止在被选元素上执行动画
    toggle() 对被选元素进行隐藏和显示的切换

    Jquery效果简单易用,能够在w3cschool中查看效果演示

    Jquery效果练习:仿QQ好友选项卡

    仿QQ好友选项卡

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title></title>
    <style type="text/css">
    *
    {
    padding: 0;
    margin: 0;
    }
    div
    {
    width: 200px;
    height: 500px;
    border: 1px solid blue;
    }
    ul
    {
    list-style-type: none;
    }
    ul li
    {
    text-align: center;
    }
    h3
    {
    background-color: Orange;
    cursor: pointer;
    margin-bottom: 2px;
    }
    </style>
    <script src="jquery-1.8.2.js" type="text/javascript"></script>
    <script type="text/javascript">
    $(function () {
    //设置好友名称的背景色
    $('h3 ~ ul > li').css({ 'backgroundColor': 'blue', 'margin-bottom': '2px' }); //为“好友组标题”注冊单击事件
    $('ul li h3').click(function () {
    $('#snd').attr('src', '1.WAV');
    $(this).next('ul').slideToggle(500);
    });
    });
    </script>
    </head>
    <body>
    <bgsound id="snd" loop="0" src="">
    <div>
    <ul>
    <li>
    <h3>
    我的好友</h3>
    <ul>
    <li>毛毛</li>
    <li>狗狗</li>
    <li>蛋蛋</li>
    </ul>
    </li>
    <li>
    <h3>
    我的同学</h3>
    <ul>
    <li>张三</li>
    <li>李四</li>
    <li>王五</li>
    </ul>
    </li>
    <li>
    <h3>
    男朋友</h3>
    <ul>
    <li>高富帅</li>
    <li>搞搞搞</li>
    <li>付福福</li>
    </ul>
    </li>
    <li>
    <h3>
    备胎</h3>
    <ul>
    <li>lyj</li>
    <li>zzz</li>
    <li>fff</li>
    </ul>
    </li>
    </ul>
    </div>
    </body>
    </html>

版权声明:本文博主原创文章,博客,未经同意不得转载。

jquery初步总结的更多相关文章

  1. 第二十篇 jQuery 初步学习2

    jQuery 初步学习2   前言:   老师这里啰嗦一下,因为考虑到一些同学,不太了解WEB前端这门语言.老师就简单的说一下,写前端,需要什么:一台笔记本.一个文本编辑器.就没啦!当然,写这门语言, ...

  2. 第十九篇 jQuery初步学习

    jQuery 初步学习   jQuery可以理解为是一种脚本,需要到网上下载,它是一个文件,后缀当然是js的文件,它里面封装了很多函数方法,我们直接调用即可,就比方说,我们用JS,写一个显示与隐藏,通 ...

  3. jQuery初步

    1.jQuery开发步骤 jQuery是第三方开源组织基于js写的一款跨主流浏览器的实用库. (1)引用第三方js库文件,<script type="text/javascript&q ...

  4. jquery 初步学习

    首先 jQuery是一个轻量级的 JS框架,核心文件才几十KB 1. jquery 对象 var $variable=jquery对象 var variable = DOM对象 $variable[0 ...

  5. day10—jQuery初步实践,关于菜单

    转行学开发,代码100天——2018-03-26 今天是本人写开发记录方面博客的第10天了,不知不觉已经涉及到jQuery框架的学习了. 第一次熬夜写前端代码还是两年前,不过中途放弃了,学的东西也日渐 ...

  6. jQuery笔记总结

    来源于:http://blog.poetries.top/2016/10/20/review-jQuery/ http://www.jianshu.com/p/f8e3936b34c9 首先,来了解一 ...

  7. 【repost】jQuery笔记总结

    第一节 jQuery初步认知 jQuery概述 JQuery概念 javascript概念 基于Js语言的API和语法组织逻辑,通过内置window和document对象,来操作内存中的DOM元素 J ...

  8. jQuery实现select三级联动

    参考:jQuery权威指南jQuery初步jQuery选择器jQuery操作domjQuery操作dom事件jQuery插件jQuery操作AjaxjQuery动画与特效jQuery实现导航栏jQue ...

  9. jQuery实现点击式选项卡

    参考:jQuery权威指南jQuery初步jQuery选择器jQuery操作domjQuery操作dom事件jQuery插件jQuery操作AjaxjQuery动画与特效jQuery实现导航栏jQue ...

随机推荐

  1. 动画(Animation) 它 (闪烁、左右摇摆、跷跷板等功效)

    一侧到另一侧的影响: (这里显示的是并不那么顺利) 一.续播  (不知道取什么名字好,就是先播放动画A, 接着播放动画B) 有两种方式. 第一种.分别动画两个动画,A和B, 然后先播放动画A,设置A ...

  2. [状压dp] hdu 4064 Carcassonne

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4064 Carcassonne Time Limit: 3000/1000 MS (Java/Othe ...

  3. Android KitKat 4.4 Wifi移植AP模式和网络共享的调试日志

    Tethering技术在移动平台上已经运用的越来越广泛了.它能够把移动设备当做一个接入点,其它的设备能够通过Wi-Fi.USB或是Bluetooth等方式连接到此移动设备.在Android中能够将Wi ...

  4. 重新想象 Windows 8 Store Apps (22) - 文件系统: 访问文件夹和文件, 通过 AQS 搜索本地文件

    原文:重新想象 Windows 8 Store Apps (22) - 文件系统: 访问文件夹和文件, 通过 AQS 搜索本地文件 [源码下载] 重新想象 Windows 8 Store Apps ( ...

  5. 移动web:图片切换(焦点图)

    在web页面上图片切换(焦点图)效果实在是太常见了,PC端.移动端到处都有它的身影. 上次写了个tab选项卡的效果,在这里延续一下,改成图片切换的效果. 如果不需要自动播放,稍微修改下html标签.和 ...

  6. Directx11学习笔记【二十】 使用DirectX Tool Kit加载mesh

    本文由zhangbaochong原创,转载请注明出处:http://www.cnblogs.com/zhangbaochong/p/5788482.html 现在directx已经不再支持.x文件了, ...

  7. poj 3414 Pots (bfs+线索)

    Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10071   Accepted: 4237   Special J ...

  8. 乐在其中设计模式(C#) - 状态模式(State Pattern)

    原文:乐在其中设计模式(C#) - 状态模式(State Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 状态模式(State Pattern) 作者:webabcd 介绍 允 ...

  9. 返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, .net 4.5 带来的更方便的异步操作

    原文:返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, ...

  10. linux进程通信之共享内存

    共享内存同意两个或多个进程共享一给定的存储区,由于数据不须要来回复制,所以是最快的一种进程间通信机制.共享内存能够通过mmap()映射普通文件(特殊情况下还能够採用匿名映射)机制实现,也能够通过系统V ...