Fork me on GitHub

jQuery 知识

本系列文章在 https://github.com/freestylefly/javaStudy 持(huan)续(ying)更(jia)新(入)中,欢迎有兴趣的童鞋们关注。

一、jQuery概述

1、什么是jQuery?

jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。jQuery设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。

2、jQuery的核心特性

jQuery的核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。jQuery兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等

3、JQuery的作用:

  • 写更少的代码,做更多的事情: write Less ,Do more
  • 将我们页面的JS代码和HTML页面代码进行分离

二、jQuery入门

1、JQ的语法结构

1、页面加载完成事件

$(document)..ready(function(){})

$(document).ready()与window.onload类似,但也有区别

window.onload $(document).ready()
执行时机 必须等待网页中所有的内容加载完毕后(包括图片、flash、视频等)才能执行 网页中所有DOM文档结构绘制完毕后即刻执行,可能与DOM元素关联的内容(图片、flash、视频等)并没有加载完
编写个数 同一页面不能同时编写多个 同一页面能同时编写多个
简化写法 $(function(){

$(selector).action()

$()工厂函数,将dom对象转换为JQ对象

selector:选择器

action():方法,有事件处理方法

2、JQ的开发步骤:

1
2
3
4
5
6
7
8
9
10
1. 导入JQ相关的文件
<script type="text/javascript" src="js/jquery-1.11.0.js"></script>
通过选择器选择对哪个对象进行操作
2. 文档加载完成事件: $(function) : 页面初始化的操作: 绑定事件, 启动页面定时器
$(function () {}——简写
$(document)..ready(function(){}) _ 一般写法
3. 确定相关操作的事件
用JQ选择器选定要绑定事件的按钮或者元素,通过.事件的方法绑定时间,里面再嵌套一个函数
4. 事件触发函数
5. 函数里面再去操作相关的元素

3、JS和JQ文档流加载区别

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
<script>
//js文档加载完成的事件
window.onload = function(){
alert("window.onload 111");
}

window.onload = function(){
alert("window.onload 222");
}

/*文档加载完成的事件*/
jQuery(document).ready(function(){
alert("jQuery(document).ready(function()");
});
/*
jQuery 简写成 $
*/
$(document).ready(function(){
alert("$(document).ready(function()");
});

/*
最简单的写法
*/
$(function(){
alert("$(function(){");
});

</script>

js会覆盖,而JQ不会覆盖

  • 脚本从上到下执行
  • onload事件是在页面先加载完再执行,
  • JQ中的页面加载完成事件在页面加载完成后执行但是速度比onload要快,所以脚本文件一般写在页面最底部

3、JQ和JS之间的转换

  • JQ对象,只能调用JQ的属性和方法
  • JS对象 只能调用JS的属性和方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
function changeJS(){
var div = document.getElementById("div1");
// div.innerHTML = "JS成功修改了内容"
//将JS对象转成JQ对象
$(div).html("转成JQ对象来修改内容")
}

$(function(){
//给按钮绑定事件
$("#btn2").click(function(){
//找到div1
// $("#div1").html("JQ方式成功修改了内容");
//将JQ对象转成JS对象来调用
var $div = $("#div1");
// var jsDiv = $div.get(0);
var jsDiv = $div[0];
jsDiv.innerHTML="jq转成JS对象成功";
});
});

4、JQ操作样式

1、css()方法

单个样式:css(“属性”,”属性值”)

多个样式:css(“属性”:”属性值”,”属性”:”属性值”);

2、addClass()方法:在括号内直接写类名即可,不用加点

样式多的时候使用

链式操作(选择器选择了一个元素.next()代表下一个元素,children(”a”)代表下一个名字是a的子元素)和隐式迭代

5、JQ常用方法

mouseover():鼠标悬浮

mouseout():鼠标移出

show():显示

hide():隐藏

index()方法,用于获取对应元素在父级中的下标

1
2
3
4
5
6
7
8
9
10
11
12
$(".nav ul li").click(function(){
var index = $(".nav ul li").index(this);
$(".nav ul li:eq(" + index + ") dt").toggle(
function(){
$(".nav ul li:eq(" + index + ") dd").slideDown();
},
function () {
$(".nav ul li:eq(" + index + ") dd").slideUp();
}
)

});

三、JQuery中的选择器

JQ选择器

1、基本选择器

  • ID选择器 : #ID的名称
  • 类选择器: 以 . 开头 .类名
  • 元素(标签)选择器: 标签的名称
  • 通配符(全局)选择器: *
  • 并集选择器: 选择器1,选择器2

案例:

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
<!--
- ID选择器 : #ID的名称
- 类选择器: 以 . 开头 .类名
- 元素选择器: 标签的名称
- 通配符选择器: *
- 选择器,选择器: 选择器1,选择器2
-->
<script>
//文档加载事件,页面初始化的操作
$(function(){
//初始化操作: 给按钮绑定事件
$("#btn1").click(function(){
$("#two").css("background-color","palegreen");
});

//找出mini类的所有元素
$("#btn2").click(function(){
$(".mini").css("background-color","palegreen");
});
$("#btn3").click(function(){
$("div").css("background-color","palegreen");
});
$("#btn4").click(function(){
$("*").css("background-color","palegreen");

});
/*选择器分组*/

//找出mini类 和 span元素
$("#btn5").click(function(){
$(".mini,span").css("background-color","palegreen");
});
});
</script>

2、层级选择器

  • 子元素选择器: 选择器1 > 选择器2(只能是儿子)
  • 后代选择器: 选择器1 儿孙
  • 相邻兄弟选择器 : 选择器1 + 选择器2 : 找出紧挨着的同辈元素(第一个弟弟)
  • 通用兄弟选择器: 选择器1~ 选择器2 : 找出所有选择器1之后的同辈元素
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<script>
//文档加载事件,页面初始化的操作
$(function(){
//初始化操作: 给按钮绑定事件
//找出body下面的子div
$("#btn1").click(function(){
$("body > div").css("background-color","palegreen");
});
//找出body下面的所有div
$("#btn2").click(function(){
$("body div").css("background-color","palegreen");
});
$("#btn3").click(function(){
$("#one+div").css("background-color","palegreen");
});
$("#btn4").click(function(){
$("#two~div").css("background-color","palegreen");
});

});
</script>

3、属性选择器

  • a[name]含有属性名为name的元素
  • a[name=”value”]有属性名为name的属性值为value元素
  • a[name^=”value”]含有属性名为name的属性值以value开头元素
  • a[name$=”value”]含有属性名为name的属性值以value结尾元素
  • a[name*=”value”]含有属性名为name的属性值包含value的元素

4、JQ中的基本过滤器

通过特定的过滤规则来筛选出所需的元素

  1. 基本过滤选择器(索引一律从0开始)

    ::even:选取索引为偶数的元素

    ::odd:选取索引为奇数的元素

    eq(index):选取索引为index的元素

    :gt(index):选取索引大于index的元素

    :lt(index):选取索引小于index的元素

    :header:选取所有标题元素(h1-h6)

    :focus:选取当前获取焦点的元素

    :animated:选取所有动画

  2. 可见性过滤选择器s

    hidden:选择所有隐藏的元素(能选到display-none、hide()、type=“hidden”

    visible:选择所有可见的元素

  3. 表单对象

  4. 内容/子元素过滤选择器

特殊符号的转义:\

选择器的书写规范很严格,多一个空格或少一个空格,都会影响选择器的效果

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
<script>
$(function(){
/<script>
//文档加载事件,页面初始化的操作
$(function(){

//初始化操作: 给按钮绑定事件
//过滤出所有div中第一个元素
$("#btn1").click(function(){
$("div:first").css("background-color","palegreen");
});

//过滤出所有div中偶数位的div
$("#btn2").click(function(){
$("div:even").css("background-color","palegreen");
});
$("#btn3").click(function(){
$("div:odd").css("background-color","palegreen");
});
$("#btn4").click(function(){
$("div:gt(2)").css("background-color","palegreen");
});

});
</script>

5、JQ中的属性选择器

1
2
3
4
5
6
7
8
9
10
11
12
$(function(){
//找到有name属性的input
$("#btn1").click(function(){
$("input[name]").attr("checked",true);
});
$("#btn2").click(function(){
$("input[name='accept']").attr("checked",true);
});
$("#btn3").click(function(){
$("input[name='newsletter'][value='Hot Fuzz']").attr("checked",true);
});
});

5、JQ中的表单过滤器

:selected

:checked

JQ中用的是submit()方法提交表单

JS用的是onsubmit=“return login

1
2
3
4
5
6
<script>
//1.文档加载事件
$(function(){
$(":text").css("background-color","pink");
});
</script>

四、JQ中常用函数及遍历数组

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
$(function)  : 文档加载完成的事件
css() : 修改css样式
prop() : 修改属性/ 获取属性
html() : 修改innerHTML

append : 给自己添加子节点
appendTo : 将自己添加到别人家,给自己找一个爹
prepend : 在自己最前面添加子节点
after : 在自己后面添加一个兄弟
empty : 清空所有子节点

遍历子元素
children()方法可以用来获取元素的所有子元素
遍历同辈元素
next()用于获取紧邻匹配元素之后的元素
prev()用于获取紧邻匹配元素之前的元素
slibings()用于获取位于匹配元素前面和后面的所有同辈元素
遍历前辈元素
parent()获取元素的父级元素
parents():元素元素的祖先元素

each( ) :规定为每个匹配元素规定运行的函数
$(cities).each(function(i,n){

})

$.each(arr,function(index,element){

});
end()将当前对象向上一级返回,:结束当前链条中的最近的筛选操作,并将匹配元素集还原为之前的状态,如
$("ul li").first().css("color","red").end().last()选择的是ul下面的最后一个li

五、JQ中的事件和动画效果

1、事件

JQ中的事件

1、基础事件

  • 鼠标事件

    click():鼠标点击

    mouseover/mouseout:鼠标悬浮/离开(被选元素+子元素)

    mouseenter/mouseleave:鼠标悬浮/离开(被选元素)

  • 键盘事件

    keydown /keyup:键盘按下和松开

    keypress:键盘按下产生可打印的字符时

    按下回车键触发的特效

    1
    2
    3
    4
    5
    $(document).keydown(function(even){
    if(even.keyCode==13){
    alert("确认要提交吗?)
    }
    })
  • window事件

    resize():浏览器事件,调整窗口大小时,完成页面特效

  • 表单事件

    常用于搜索框,未点击搜索框时,有提示信息,点击搜索框时候提示信息就消失了

    鼠标聚焦:focus

    失去焦点:blur

2、复合事件

  • 鼠标光标悬停

    hover()方法相当于mouseover与mouseout事件的组合

    hover(fn1,fn2)

  • 鼠标连续点击

    toggle()方法用于模拟鼠标连续click事件

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    1、toggle():
    与show( )和hide( )方法作用一样,点击显示,再点击隐藏
    2、toggle(fn1,fn2,...),仅支持1.8.0以上版本
    点击几次就有几个function
    $("input:first").toggle(
    function(){
    $("div").css("background","red");
    },
    function(){
    $("div").css("background","blue");
    },
    function(){
    $("div").css("background","green");
    }
    );
    3、toggleClass()可以对样式进行切换,前提是先要在css样式中写上相应的类样式,如:.red
    $("input:last").click(function(){
    $("p").toggleClass("red");
    });

3、绑定和移出事件

  • 绑定:on/bind

(on和bind都可以用作事件绑定,但是on绑定事件对于新增元素也有效)

1
2
3
4
5
6
7
8
9
1、绑定单个事件:
on("click",function(){})
2、绑定多个事件
on(
{
"click":a=function(){},
"click":b=funtioon(){}
}
)
  • 移出绑定off/unbind
1
2
3
4
5
移出绑定前需要对绑定的事件命名
1、移出所有绑定的事件
off()
2、移出指定名字的事件
off("click",a)

2、动画效果

  • show()显示

  • hide()隐藏

  • slideUp使元素逐步缩短直至隐藏

  • slideDown可以使元素逐步延伸显示

  • fadeIn

  • fadeOut

  • animate : 自定义动画:

    $(selector).
    animate({params},speed,callback)

    params:必须,定义形成动画的CSS属性

    stop:

    无参:停止当前

    一个参数:停止所有

    两个参数:停止所有,并回到动画最终的位置

六、jQuery中的DOM操作

1、css操作

  • 添加样式

    1. css(),单个样式css(“name”,”value”),多个样式:css(“{name1”:”value1”,”name2”,”value2”})

    2. addClass:添加类样式,多个用空格隔开

    3. height:设置或返回匹配元素的高度

    4. width:设置或返回匹配元素的宽度

    5. offset:返回以像素为单位的top和left坐标。仅对可见元素有效

    6. offsetParent:返回最近的已定位祖先元素。定位元素指的是元素的CSS
      position值被设置为relative、absolute或fixed的元素

    7. position:返回第一个匹配元素相对于父元素的位置

    8. scrollLeft:参数可选。设置或返回匹配元素相对滚动条左侧的偏移

    9. scrollTop:参数可选。设置或返回匹配元素相对滚动条顶

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      制作页面小广告随滚动条滚动
      $(document).ready(function(){
      //获取初识位置
      var topEle=parseInt($("#adver").css("top"));
      var leftEle=parseInt($("#adver").css("left"));

      //滚轮滚动事件
      $(window).scroll(function () {
      //获取该变量
      var changeTop=$(this).scrollTop();
      var changeLeft=$(this).scrollLeft();

      //得到改变后的位置
      var endTop=changeTop+topEle+"px";
      var endLeft=changeLeft+leftEle+"px";

      $("#adver").css({"top":endTop,"left":endLeft});
      })
      })
  • 移除样式

    removeClass

  • 切换样式

    toggleClass(需要和hover一起使用)

  • 判断是否包含某样式

    haseClass

2、HTML代码操作

1
2
3
html():获取元素的html代码

html("<div class='content'>…</div>");:设置元素中的HTML代码

3、标签内容操作

1
2
3
text();:获取元素中的文本内容
text("<div class='content'>…</div>");
text和html 的区别:text不会去解析HTML标签,只会解析文本

4、属性和属性值操作

1
2
3
4
val()无参代表获取value值,有值即表示设置value的值
att()获取属性
attr("class","blua")代表设置class属性
RemoveAttr():移出属性

5、节点操作

  • 创建节点

    1
    $()工厂函数可直接创建节点
  • 插入节点

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    1、有父子元素的插入
    将儿子F加到父亲E的最后(父E,子F)
    E.append(F):
    F.append(E):
    将儿子F加到父亲E的最前面(父E,子F)
    E.prepend(F):
    F.prependTo(E)
    2、插入同辈节点
    A.after(B):将B插到A的后面(beforeD代表前)
    A.insertAfter(B):将A插到B的后面(insertbeforeD代表前)
  • 删除节点

    remove:删除整个节点,包括结构

    empty:清空节点里面的内容,但结构保留

    detach:删除整个节点,但是保留事件

  • 替换节点

    replaceWith(同append)

    replaceAll(同appendTo)

  • 复制节点

    clone():纯粹复制节点

    clone(true):节点里面绑定的事件也会被复制

六、使用JQuery完成页面定时弹出广告

1、 需求分析

当用户打开界面,3秒钟之后弹出广告,这个广告显示5秒钟,隐藏广告

2、 技术分析

定时器: setTimeout

显示和隐藏: style.display = “block/none”

3、步骤分析

  1. 导入JQ的文件
  2. 编写JQ的文档加载事件
  3. 启动定时器 setTimeout(“”,3000);
  4. 编写显示广告的函数
  5. 在显示广告里面再启动一个定时器
  6. 编写隐藏广告的函数

4、代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<script>
//显示广告
function showAd(){
$("#img1").slideDown(2000);
setTimeout("hideAd()",3000);
}
//隐藏广告
function hideAd(){
$("#img1").slideUp(2000);
}
$(function(){
setTimeout("showAd()",3000);
});
</script>

七、使用JQ完成表格的隔行换色

1、需求分析

在我们的实际开发过程中,我们的表格如果所有的行都是一样的话,很容易看花眼,所以我们需要让我们的表格隔行换色

2、技术分析

获取所有行 table.rows

遍历所有行

根据行号去修改每一行的背景颜色: bgColor

​ style.backgroundColor = “red”

3、步骤分析

  1. 导入JQ的包
  2. 文档加载完成函数: 页面初始化
  3. 获得所有的行 : 元素选择器
  4. 根据行号去修改颜色

5、代码实现

1
2
3
4
5
6
7
8
9
	$(function(){
//获得所有的行 : 元素选择器
$("tbody > tr:even").css("background-color","#CCCCCC");
//修改基数行
$("tbody > tr:odd").css("background-color","#FFF38F");
// $("tbody > tr").css("background-color","#FFF38F");


});

八、使用JQuery完成表单的全选全不选功能以及隔行换色

1、需求分析

在我们对表格处理的时,有些情况下,我们需要对表格进行批量处理,,隔行换色

2、代码实现:

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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/jquery-1.11.0.js"></script>
<script>

$(function () {
$("tr:even:gt(0)").css("background-color","#CCCCCc");
//鼠标点击后触发
$("tr:odd").mousedown(function(){
$("tr:odd").css("background-color","red");
});
//通过鼠标在元素上移动
$("tr:odd").mousemove(function(){
$("tr:odd").css("background-color","yellow");
});
//mouseout事件在鼠标从元素上离开后会触发
$("tr:odd").mouseout(function(){
$("tr:odd").css("background-color","blue");
});
//为元素绑定函数,点击
$("#cheack1").click(function(){
//全选和取消全选
$("input[type='checkbox']:gt(0)").prop("checked",this.checked);
$("body > table > tbody > tr:nth-child(2) > td:nth-child(1) > input[type="checkbox"]")
});

});
</script>
</head>
<body>
<table border="1px" width="300px" cellpadding="0" cellspacing="0">
<tr>
<th><input type="checkbox" id="cheack1"/></th>
<th>姓名</th>
<th>年龄</th>
<th>爱好</th>
</tr>
<tr align="center">
<td><input type="checkbox"/></td>
<td >江彬</td>
<td>24</td>
<td>编程</td>
</tr>
<tr align="center">
<td><input type="checkbox"/></td>
<td>初识</td>
<td>22</td>
<td>看书</td>
</tr>
<tr align="center">
<td><input type="checkbox"/></td>
<td>张三</td>
<td>26</td>
<td>鞋子</td>
</tr>
<tr align="center">
<td><input type="checkbox"/></td>
<td>王五</td>
<td>23</td>
<td>看电影</td>
</tr>

</table>
</body>
</html>

九、使用JQ完成省市联动效果

1、需求分析

在我们的注册表单中,通常我们需要知道用户的籍贯,需要一个给用选择的项,当用户选中了省份之后,列出省下面所有的城市

2、技术分析

  1. 准备工作 : 城市信息的数据
  2. 添加节点 : appendChild (JS)
    1. append : 添加子元素到末尾
    2. appendTo : 给自己找一个爹,将自己添加到别人家里
    3. prepend : 在子元素前面添加
    4. after : 在自己的后面添加一个兄弟
  3. 遍历的操作:

3、步骤分析

  1. 导入JQ的文件
  2. 文档加载事件:页面初始化
  3. 进一步确定事件: change事件
  4. 函数: 得到当前选中省份
  5. 得到城市, 遍历城市数据
  6. 将遍历出来的城市添加到城市的select中

4、代码实现

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
43
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>省市联动效果制作</title>
<script type="text/javascript" src="js/jquery-1.11.0.js"></script>
<script>
/*
准备工作 : 准备数据
*/
var provinces = [
["深圳市","东莞市","惠州市","广州市"],
["长沙市","岳阳市","株洲市","湘潭市"],
["厦门市","福州市","漳州市","泉州市"]
];
$(function () {
$("#province").change(function(){
var citys=provinces[this.value];
//清空城市信息
$("#city").empty();
//遍历城市信息
$(citys).each(function(i,n){
$("#city").append("<option>"+n+"</option>");
})

});
});
</script>
</head>
<body>
<!--选择省份-->
<select name="sheng" id="province">
<option value="1">请选择</option>
<option value="0">广东</option>
<option value="1">湖南</option>
<option value="2">福建</option>
</select>
<!--选择城市-->
<select name="city" id="city">

</select>
</body>
</html>

十、使用JQ完成下拉列表左右选择

1、代码实现

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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="js/jquery-1.11.0.js" ></script>
<script>
$(function(){
//双击添加至右边
$("#leftSelect option").dblclick(function(){
$("#rightSelect").append($("#leftSelect option:selected"));
});
$("#a1").click(function(){
//找到被选中的那一项
//将被选中项添加到右边
$("#rightSelect").append($("#leftSelect option:selected"));
});

//将左边所有商品移动到右边
$("#a2").click(function(){
$("#rightSelect").append($("#leftSelect option"));
});

//将右边商品点击选中放入左边
$("#b1").click(function(){
$("#leftSelect").append($("#rightSelect option:selected"))
})
//将右边所有商品选中放入左边
$("#b2").click(function(){
$("#leftSelect").append($("#rightSelect option"))
})
//双击添加至左边
$("#rightSelect option").dblclick(function(){
$("#leftSelect").append($("#rightSelect option:selected"))
});
});
</script>
</head>
<body>
<table border="1px" width="400px">
<tr>
<td>分类名称</td>
<td><input type="text" value="手机数码"/></td>
</tr>
<tr>
<td>分类描述</td>
<td><input type="text" value="这里面都是手机数码"/></td>
</tr>
<tr>
<td>分类商品</td>
<td>
<!--左边-->
<div style="float: left;">
已有商品<br/>
<select multiple="multiple" id="leftSelect">
<option>华为</option>
<option>小米</option>
<option>锤子</option>
<option>oppo</option>
</select>
<br/>
<a href="#" id="a1"> &gt;&gt; </a> <br/>
<a href="#" id="a2"> &gt;&gt;&gt; </a>
</div>
<!--右边-->
<div style="float: right;">
未有商品<br/>
<select multiple="multiple" id="rightSelect">
<option>苹果6</option>
<option>肾7</option>
<option>诺基亚</option>
<option>波导</option>
</select>
<br/>
<a href="#" id="b1"> &lt;&lt; </a> <br/>
<a href="#" id="b2"> &lt;&lt;&lt; </a>
</div>
</td>
</tr>
<tr>
<td colspan="2">
<input type="submit" value="提交"/>
</td>
</tr>
</table>
</body>
</html>

十一、JQ完成表单表单验证

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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
$(document).ready(function () {
//失焦事件
$("#fname").blur(checkFname);
$("#lname").blur(checklname);
$("#sname").blur(checkSname);
$("#pass").blur(checkPassword);
$("#email").blur(checkEmail);


//聚焦


//表单提交
$("#formRegister").submit(function(){
if(!checkFname()){
return false;
}else if(!checklname()){
return false;
}else if(!checkSname()){
return false;
}else if(!checkPassword()){
return false;
}else if(!checkEmail()){
return false;
}
return true;
})



//验证名字
function checkFname(){
if($("#fname").val()==""){
$("#spanfname").html("名字不能为空").css("color","red");
return false;
}else{
$("#spanfname").html("");
}
return true;
};
//验证姓氏
function checklname(){
if($("#lname").val()==""){
$("#spanlname").html("姓氏不能为空").css("color","red");
return false;
}else{
$("#spanlname").html("");
}
return true;
};
//验证登录名
function checkSname(){
var sname=$("#sname").val();
var reg=/^[a-z0-9_]$/;
if(sname==""){
$("#spansname").html("登录名不能为空").css("color","red");
return false;
}else if(reg.test(sname)==false){
$("#spansname").html("登录名格式不正确").css("color","red");
return false;
}else{
$("#spansname").html("");
}

return true;
};

//验证密码
function checkPassword(){
var psd=$("#pass").val();
//if(psd==""){
// $("#spanpass").html("密码不能为空").css("color","red");
// return false;
//}else if(psd.length<6){
// $("#spanpass").html("密码不能少于6位").css("color","red");
// return false;
//}else{
// $("#spanpass").html("");
//}
var reg=/^\w{6}$/;
if(psd==""){
$("#spanpass").html("密码不能为空").css("color","red");
return false;
}else if(reg.test(psd)==false){
$("#spanpass").html("密码不能少于6位").css("color","red");
return false;
}else{
$("#spanpass").html("");
}
return true;
};
//验证邮箱
function checkEmail(){
var email=$("#email").val();
//if(email==""){
// $("#spanemail").html("不能为空").css("color","red");
// return false;
//}else if(email.indexOf("@")==-1){
// $("#spanemail").html("必须含有@符号").css("color","red");
// return false;
//}else if(email.indexOf(".")==-1) {
// $("#spanemail").html("必须含有.符号").css("color", "red");
// return false;
//}else{
// $("#spanemail").html("");
//}
var reg=/^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.]{2,6})$/;
if(reg.test(email)==false){
$("#spanemail").html("邮箱格式不正确").css("color","red");
return false;
}else{
$("#spanemail").html("");
}
return true;
};


})

补充:使用HTML5进行表单验证

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
/**
* JS代码
Created by zongjuan.wang on 2016/7/6.
*/

$(document).ready(function(){
$("#submit").click(function(){
var u=document.getElementById("uName");
if(u.validity.valueMissing==true){//输入为空
u.setCustomValidity("昵称不能为空");//自定义错误提示信息
}
else if(u.validity.patternMismatch==true){//输入内容格式与正则表达式不匹配
u.setCustomValidity("昵称必须是6~10位的英文和数字");
}
else{
u.setCustomValidity("");
}

var pwd=document.getElementById("pwd");
if(pwd.validity.valueMissing==true){
pwd.setCustomValidity("密码不能为空");
}
else if(pwd.validity.patternMismatch==true){
pwd.setCustomValidity("密码必须是6~16位的英文和数字");
}
else{
pwd.setCustomValidity("");
}

var email=document.getElementById("email");
if(email.validity.valueMissing==true){
email.setCustomValidity("邮箱不能为空");
}
else if(email.validity.typeMismatch==true){
email.setCustomValidity("邮箱格式不正确");
}
else{
email.setCustomValidity("");
}

})
})

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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>仿QQ注册</title>
<link href="css/style.css" rel="stylesheet"/>
</head>
<body>
<div class="container">
<h2 class="reg-top"></h2>
<div class="reg-box">
<div class="reg-main">
<h3>注册账号</h3>
<form action="index.html" method="post" class="reg-form">
<div class="reg-input">
<label><i>*</i>昵称:</label>
<input type="text" id="uName" required placeholder="英文、数字长度为6-10个字符" pattern="[a-zA-Z0-9]{6,10}" />
</div>
<div class="reg-input">
<label><i>*</i>密码:</label>
<input type="password" id="pwd" required placeholder="长度为6-16个字符" pattern="[a-zA-Z0-9]{6,16}"/>
</div>
<div class="reg-input">
<label>手机号码:</label>
<input type="text" pattern="^1[34578][0-9]{9}$"/>
<span id="tel-tip">忘记密码时找回密码使用</span>
</div>
<div class="reg-input">
<label><i>*</i>邮箱:</label>
<input type="email" required id="email"/>
</div>
<div class="reg-input">
<label>年龄:</label>
<input type="number" min="12"/>
</div>
<div class="submit-box">
<input type="submit" id="submit" value="立即注册" >
</div>
</form>
</div>
</div>
</div>
<script src="js/jquery-1.12.4.js"></script>
<script src="js/reg.js"></script>

</body>
</html>

十二、正则表达式

1、声明

1
var reg=/^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.]{2,6})$/;

2、test方法

1
if(reg.test(email)==false){

3、手册及常用正则表达式

http://tool.oschina.net/uploads/apidocs/jquery/regexp.html

4、String对象与正则表达式

方法 描述
match() 找到一个或多个正则表达式的匹配
search() 检索与正则表达式相匹配的值
replace() 替换与正则表达式相匹配的字符串
split() 把字符串分割成字符串数组

g代表全局匹配,i代表忽略大小写


本文章已同步至我的GitHub仓库:Javastudy,期待您的加入:blush:

本文章已同步至苍何的个人博客,可以直接在博客上留言哦:blush:

来我的微信公众号玩耍呗:blush:

扫码无套路关注我的CSDN博客:blush:

苍 何 wechat
欢迎您扫一扫上面的微信公众号,订阅我的博客!
-------------本文结束感谢您的阅读-------------
坚持原创技术分享,您的支持将鼓励我继续创作!