一.常用的JavaScript库对比

Prototype、Dojo、YUI、Mootools

jQuery是一个轻量级的JavaScript库,大型开发必备——由John Resig于2006年创建。

jQuery的理念是:写得少做得多。

优势:简化了Js的复杂操作,不再关心兼容性,大量的实用方法。

怎样学习:看api文档

但是jq只是辅助工具——要正确面对。

二.使用jQ

代码导入和js一样。

$的意义:是jQuery的简写形式

$('#btn1')等价于jQuery('#btn1')

引入jq之后,编写

1
2
3
$(document).ready(function(){
    alert('hello world!');
})

基本等价于window.onload=function(){alert('hello world!')}。

不过还是有所区别。

三.jQuery的代码风格

1.链式操作

【例1.1】导航栏

项目需求:做一个导航栏,单击不同的商品链接,显示相应内容,同时高亮显示当前选择的商品。

分析:这是结合了css的效果

html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<ul id="nav">
    <li class="level1">
        <h4 style="border-top:none">罗大佑</h4>
        <ul class="level2">
            <li>恋曲1980</li>
            <li>鹿港小镇</li>
            <li>东方之珠</li>
        </ul>
    </li>
 
     <li class="level1">
        <h4>周华健</h4>
        <ul class="level2">
            <li>怕黑</li>
            <li>雨人</li>
            <li>最近比较烦</li>
            <li>花海</li>
        </ul>
    </li>
 
     <li class="level1">
        <h4>李宗盛</h4>
        <ul class="level2">
            <li>凡人歌</li>
            <li>寂寞难耐</li>
            <li>明明白白我的心</li>
            <li>我终于失去了你</li>
        </ul>
    </li>
</ul>

css

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
*{
    margin:0;
    padding:0;
}
ul li{
    list-stylenone;
}
a{
    text-decorationnone;
}
#nav{
    width300px;
    border1px solid rgb(196,213,223);
    margin100px auto;
}
#nav>li>h4{
    backgroundrgb(235,243,248);
    border-top1px solid rgb(196,213,223);
     
    line-height40px;text-aligncenter;
    font-size20px;colorrgb(88,147,183);
    cursorpointer;
 
}
#nav>li>ul>li{
    background#fff;
     
    line-height40px;text-aligncenter;
    font-size20px;colorrgb(88,147,183);
    cursorpointer;
}
#nav>li>ul>li:hover{
    color:rgb(255,102,0);
}
.level2{
    displaynone;
}
#nav .current{
    backgroundrgb(177,215,239);
    border-top1px solid rgb(196,213,223);
    border-bottom1px solid rgb(196,213,223);
}

js

1
2
3
4
5
6
7
8
9
$(document).ready(function(){
    $(".level1 > h4").click(function(){
        $(this).addClass("current")//当标题被点击时,给被点击的对象加上currentclass
        .next().show()//标题的下一个元素,也就是level2——展现出来。
        .parent().siblings().children("h4").removeClass("current").next().hide();
        //标题的父元素——的兄弟元素——的子元素——中的h4——移出current的class,同时——下一个level2隐藏。
        return false;
    });
});

2.良好的代码风格即是一切

一般而言,jQuery可以用一行完成很多行才能完成的东西。但是太长了也不是都看得懂的。

首先

a.同一对象不超过3次操作的,可写成1行,

b.同一对象多个操作,每个操作一行

c.多个对象少量操作,可以每个对象1行。如果涉及子元素,可适当缩进。

其次,加上注释!

三. 区别jQuery对象和DOM对象

1. 特点

jQuery对象是DOM对象通过jQuery.js包装后产生的。可以使用jQuery方法,但不能使用任何DOM对象的方法。以下列出相关方法对比

DOM对象方法 JQ对象方法
document.getElemntById('OBJ').innerHTML $('#OBJ').html()
document.getElemntById('OBJ').checked $('#OBJ').attr('checked')

2. 转换

jQuery对象:在前面加一个$以示和Dom变量的区别

(1)jQuery对象转dom对象

jQuery对象类似一个数组,假设存在一个jQuery对象$('#cr'),以下两种方法都是可以的:

1
2
3
var $oCr=$('#cr');
var oCr=$oCr[0];
var oCr=$oCr.get(0)

(2)DOM转jQuery对象

只需要把dom对象用$()包起来。

1
2
var oCr=document.getElementById('cr');
var $oCr=$(oCr);

$()函数就是jQuery对象的制造工厂。

【例1.2】做一个注册页面。点击阅读并同意,反馈可以继续操作

1
2
<input type="checkbox" id="cr"/>
<label for="cr">我已经阅读了上面制度.</label>

(1)DOM方式

1
2
3
4
5
6
7
8
9
window.onload=function(){
    var oCr=document.getElementById('cr');
 
    oCr.onclick=function(){
        if(oCr.checked){
            alert('可以继续操作!');
        }
    }
}

(2)jQuery方式

1
2
3
4
5
6
7
8
9
$(document).ready(function(){
    var $oCr=$('#cr');
 
    $oCr.click(function(){
        if($oCr.is(':checked')){
            alert('可以继续操作!');
        }
    })
})

第1章 认识jQuery的更多相关文章

  1. 第一章 认识jQuery

    jQuery是一个优秀的JavaScript库,它凭借简洁地语法和跨平台的兼容性,极大地简化了开发人员遍历HTML文档,操作DOM,处理事件,执行动画和开发Ajax操作. jQuery优势:1.轻量级 ...

  2. 第四章 使用jQuery操作DOM

    第四章 使用jQuery操作DOM 一.DOM操作 在jQuery中的DOM操作主要可分为样式操作.文本和value属性值操作.节点操作: 节点操作又包含属性操作.节点遍历和CSS-DOM操作. 其中 ...

  3. 《锋利的jQuery(第2版)》笔记-第1章-认识jQuery

    jQuery是随着Web2.0兴起的JavaScript库之一,因为其独特的优点,受到越来越多人的追捧! 1.1 JavaScript和JavaScript库 1.1.1 JavaScript简介 J ...

  4. 第十七章:jQuery类库

    javascript的核心API设计的很简单,但由于浏览器之间的不兼容性,导致客户端的API过于复杂.IE9的到来缓解了这种情况.然而使用javascript的框架或者工具类库,能简化通用操作,处理浏 ...

  5. JavaScript交互式网页设计 • 【第6章 初识jQuery】

    全部章节   >>>> 本章目录 6.1 jQuery概述 6.1.1 初识 jQuery 6.1.2 jQuery 基本功能 6.1.3 搭建 jQuery 开发环境 6.1 ...

  6. 三、jQuery--jQuery基础--jQuery基础课程--第1章 初识jQuery

    环境搭建 搭建一个jQuery的开发环境非常方便,可以通过下列几个步骤进行. 下载jQuery文件库 在jQuery的官方网站(http://jquery.com)中,下载最新版本的jQuery文件库 ...

  7. 第三章:初识Jquery

    一.Jquery的优势 体积小,压缩后只有100KB左右 强大的选择器 出色的DOM封装 可靠的事件处理机制 出色的浏览器兼容性 使用隐式迭代简化编程 丰富的插件支持 二.Jquery语法 三.DOM ...

  8. 第三章(jQuery中的DOM操作)

    3.1 DOM 操作分类 ①DOM Core 包括(getElementById() , getElementsByTagName() , getAttribute() , setAttribute( ...

  9. 第二章(jQuery选择器)

    2.1jQuery选择器是什么 1.CSS选择器 选择器 示例 选择器 示例 标签选择器 a{ } p{ } ul{ } ID选择器 #ID{ } 类选择器 .class{ } 群组选择器 td,p, ...

随机推荐

  1. TouchSlop与VelocityTracker认识

    TouchSlop是处理触摸事件中的一个常量,被系统认为滑动和点击事件的临界点.理 解这个touchSlop是一个滑动距离值的常量,也就是说当我们手触摸在屏幕上滑动时,如果滑动距离没有超过touchS ...

  2. [转]扩展RBAC用户角色权限设计方案

    原文地址:http://www.iteye.com/topic/930648 RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地 ...

  3. datatable绑定comboBox显示数据[C#]

    实现功能: datatable绑定comboBox,在下拉菜单中显示对应数据 实现方法: 1.生成datatable,并为combox绑定数据源: comboBox1.DataSource = dt1 ...

  4. 终于有SpringMvc与Struts2的对比啦

    目前企业中使用SpringMvc的比例已经远远超过Struts2,那么两者到底有什么区别,是很多初学者比较关注的问题,下面我们就来对SpringMvc和Struts2进行各方面的比较: 1. 核 心控 ...

  5. SQL Server 自增字段重置

    --- 删除原表数据,并重置自增列 truncate table tablename --truncate方式也可以重置自增字段 --重置表的自增字段,保留数据 DBCC CHECKIDENT (ta ...

  6. Hive 的分桶 & Parquet 概念

    分区 & 分桶 都是把数据划分成块.分区是粗粒度的划分,桶是细粒度的划分,这样做为了可以让查询发生在小范围的数据上以提高效率. 分区之后,分区列都成了文件目录,从而查询时定位到文件目录,子数据 ...

  7. (转)CSS的Sprites技术

    Css Sprites 技术逐渐流行,各大网站上都可以看到它的身影. 但从本质上,Css Sprites 只是 Css 技术的一个使用小窍门,初学者也能快速上手. Css Sprites 简单解释: ...

  8. [NOIP2015] 提高组 洛谷P2680 运输计划

    题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 L 国有 n 个星球,还有 n-1 条双向航道,每条航道建立在两个星球之间,这 n-1 条航道连通了 L 国的所有星球. 小 P 掌管一家 ...

  9. bzoj2588 Count on a tree

    题意:给定一棵树,有点权,不带修改,询问路径点权第K大,强制在线. 这道题建主席树的方法好机智.按照BFS/DFS序建树,对于每个点,建出"这个点到根节点的路径上的点"组成的权值线 ...

  10. C#变量类型

    在C#语言中,我们把变量分为七种类型,它们分别是:静态变量(static varibles),非静态变量(instance variables),数组元素(array elements),值参数(va ...