ImageVerifierCode 换一换
格式:DOCX , 页数:24 ,大小:34.60KB ,
资源ID:3734721      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3734721.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(第19章 JavaScript语言.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

第19章 JavaScript语言.docx

1、第19章 JavaScript语言19JavaScript语言第 章 核心要点 基本语法 表单校验 事件响应 使用技巧学习目标通过本章学习,掌握JavaScript的基本编程思想,掌握基本的语法及应用,熟悉常用的变量定义、语法结构、事件以及在页面中的应用方式,掌握几种常用的技巧。JavaScript是由Netscape公司开发、介于Java与HTML之间、基于对象事件驱动的编程语言。它的开发环境简单、不需要Java编译器、直接运行在Web浏览器中。JavaScript使得信息和用户之间不仅仅是一种显示和浏览的关系,而是实现了一种实时的、动态的、可交式的表达能力。19.1 JavaScript语

2、言基础JavaScript是一种基于对象(Object)和事件驱动(Event Driven)并具有安全性能的脚本语言。使用它可以与HTML超文本标记语言、Java 脚本语言(Java小程序)一起实现在一个Web页面中链接多个对象,与Web客户交互作用,从而可以开发客户端的应用程序等。它是通过嵌入或调入在标准的HTML语言中实现的。具有以下几个基本特点:1.脚本编写语言JavaScript是一种脚本语言,它采用小程序段的方式实现编程。像其它脚本语言一样,JavaScript同样已是一种解释性语言,它提供了一个易的开发过程。2.基于对象的语言JavaScript是一种基于对象的语言,同时以可以看

3、作一种面向对象的。这意味着它能运用自己已经创建的对象。因此,许多功能可以来自于脚本环境中对象的方法与脚本的相互作用。 3.简单性JavaScript的简单性主要体现在:首先它是一种基于Java基本语句和控制流之上的简单而紧凑的设计。其次它的变量类型是采用弱类型,并未使用严格的数据类型。4.安全性JavaScript是一种安全性语言,它不允许访问本地的硬盘,并不能将数据存入到服务器上,不允许对网络文档进行修改和删除,只能通过浏览器实现信息浏览或动态交互。从而有效地防止数据的丢失。 5.动态性JavaScript是动态的,它可以直接对用户或客户输入做出响应,无须经过Web服务程序。它对用户的反映响

4、应,是采用以事件驱动的方式进行的。6.跨平台性JavaScript是依赖于浏览器本身,与操作环境无关,只要能运行浏览器的计算机,并支持JavaScript的浏览器就可正确执行。从而实现了“编写一次,走遍天下”的梦想。19.1.1 语法 JavaScript脚本语言同其它语言一样,有它自身的基本数据类型、表达式和算术运算符以及程序的基本框架结构。JavaScript提供了四种基本的数据类型用来处理数字和文字, 而变量提供存放信息的地方, 表达式则可以完成较复杂的信息处理。1.基本数据类型在JavaScript中四种基本的数据类型:数值(整数和实数)、字符串型(用“”号或括起来的字符或数值)、布尔

5、型(使True或False表示)和空值。在JavaScript的基本类型中的数据可以是常量,也可以变量。由于JavaScript采用弱类型的形式,因而一个数据的变量或常量不必首先作声明,而是在使用或赋值时确定其数据的类型的。当然也可以先声明该数据的类型,它是通过在赋值时自动说明其数据类型的。2. 变量的命名变量的主要作用是存取数据、提供存放信息的容器。对于变量必须明确变量的命名、变量的类型、变量的声明及其变量的作用域。JavaScript中的变量命名同其计算机语言非常相似,这里要注意以下四点: 必须是一个有效的变量,即变量以字母开头,中间可以出现数字如test1、text2等。除下划线()作为

6、连字符外,变量名称不能有空格、()、()、(,)或其它符号。 不能使用JavaScript中的关键字作为变量。 在JavaScript中定义了多个类键字,这些关键是JavaScript内部使用的,不能作为变量的名称。如Var、int、double、true不能作为变量的名称。 在对变量命名时,最好把变量的意义与其代表的意思对应起来,以免出现错误。3.变量的类型定义了一个mytest变量:var mytest;定义了一个mytest变量, 同时赋予了它的值:Var mytest=”This is a book”;在JavaScript中,变量可以不作声明,而在使用时再根据数据的类型来确定其变量的

7、类型。例子如下。x=100 y=125 xy= True cost=19.5其中x整数,y为字符串,xy为布尔型,cost为实型。 在JavaScript中有全局变量和局部变量。全局变量是定义在所有函数体之外,其作用范围是整个函数;而局部变量是定义在函数体之内,只对其该函数是可见的,而对其它函数则是不可见的。3.常量:是在程序执行过程中值保持不变的变量。4.表达式在定义完变量后,就可以对它们进行赋值、改变、计算等一系列操作,这一过程通常又用表达式来完成,可以说表达式是变量、常量、布尔及运算符的集合,因此表达式可以分为算术表述式、字串表达式、赋值表达式以及布尔表达式等。5.函数 通常在进行一个复

8、杂的程序设计时,总是将所要完成的复杂功能划分为一些相对独立的部分,每部分编写一个函数,使各部分充分独立,任务单一,程序清晰,易懂、易读、易维护。然后根据需要来组合这些函数完成最终的功能。函数的定义形式如下。Function 函数名 (参数,变元)函数体;Return 表达式;在函数的定义中,我们看到函数名后有参数表,这些参数变量可能是一个或几个。那么怎样才能确定参数变量的个数呢?在JavaScript中可通过arguments .Length来检查参数的个数。例如:实例19-1 arguments .Length应用程序内容如下:Function function_Name(exp1,exp2

9、,exp3,exp4)Number =function _Name.arguments.length;if (Number1)document.wrile(exp2);if (Number2)document.write(exp3);if(Number3)document.write(exp4);6.注释注释是在程序运行时被忽略的部分。JavaScript 注释有两种:单行注释和多行注释。单行注释用双反斜杠“/”表示。当一行代码有“/”,那么,“/”后面的部分将被忽略。而多行注释是用“/*”和“*/”括起来的一行到多行文字。程序执行到“/*”处,将忽略以后的所有文字,直到出现“*/”为止。19

10、.1.2 运算符运算符完成操作的一系列符号,在JavaScript中有算术运算符,如、-、*、/等;有比较运算符如!、等; 有逻辑布尔运算符如!(取反)、|、|; 有字串运算如 、 等。1、算术运算符双目运算符:+(加) 、-(减)、 *(乘)、 /(除)、 %(取模) 、|(按位或)、&(按位与)、(右移)、 (右移,零填充)。单目运算符:-(取反)、(取补)、+(递加1)、-(递减1)。2、比较运算符有个比较运算符:(大于)、=(大于等于)、=(等于)、!=(不等于)。3、布尔逻辑运算符!(取反)、&=(与之后赋值)、 &(逻辑与)、 |=(或之后赋值)、 |(逻辑或)、 =(异或之后赋值

11、)、 (逻辑异或)、 ?:(三目操作符)、|(或)、=(等于)、|=(不等于)。其中三目操作符主要格式如:操作数?结果:结果若操作数的结果为真,则表述式的结果为结果,否则为结果。19.1.3 控制和循环语句在任何一种语言中,程序控制流是必须的,它能使得整个程序减小混乱,使之顺利按其一定的方式执行。下面是JavaScript常用的程序控制流结构及语句:1.if条件语句if(表述式)语句段;.Else语句段;.功能:若表达式为true,则执行语句段;否则执行语句段。2.For循环语句for(初始化;条件;增量)语句集;功能:实现条件循环,当条件成立时,执行语句集,否则跳出循环体。3.while循环

12、while(条件)语句集;该语句与For语句一样,当条件为真时,重复循环,否则退出循环。4.break和continue语句与C+语言相同,使用break语句使得循环从For或while中跳出,continue使得跳过循环内剩余的语句而进入下一次循环。实例19-2 跑马灯程序内容如下:var msg=这是一个跑马灯效果的JavaScript文档;var interval = 100; var spacelen = 120; var space10= ; var seq=0;function Scroll() len = msg.length;window.status = msg.substr

13、ing(0, seq+1);seq+;if ( seq = len ) seq = spacelen; window.setTimeout(Scroll2();, interval );elsewindow.setTimeout(Scroll();, interval ); function Scroll2() var out=;for (i=1; i= len ) seq = 0; ;window.setTimeout(Scroll2();, interval ); Scroll();19.2 表单校验19.2.1 客户输入的有效性校验表单的有效性检验是JavaScript一个很有用的方面。

14、它可以用于检查一个给定的表单以及发现表单中的任何问题,比如一个空白的输入框或者一个无效的E-mail(电子邮件)地址,然后它可以通知用户并且就不会将这些错误的表单传给服务器以节省时间。另外,除此以外,对表单标签的一些修改跟其它类型的脚本是类似的。以下的例子是一个简单的表单,如下面表单所示。你可以让名字的方框留空白或者输入一个电子邮件地址而没有符号,即是输入错误的内容,看看JavaScript是进行表单的有效性检验的。实例19-3 数据校验程序内容如下:function formCheck()if (document.theform.user_name.value = )alert(Please

15、 put in a name.);return false;if (document.theform.email.value.indexOf() = -1 h_| document.theform.email.value = ) alert(Please include a proper email address.);return false;首先,formCheck()函数判断是否用户名字输入为空。如果为空,它也会警告用户并返回false值,这个表单也不会发送给服务器。接着formCheck()函数是判断是否Email地址输入包含一个符号或者是空的。如果没有包含符号或者是空的的任何一种情况

16、,它就会警告用户并返回false值,这样这个表单就不会发送给服务器了。以上的任何一种错误都不会将表单发送给服务器的,直到正确填写完整个表单之后才将表单发送给服务器。以上程序的原理实质是获得表单中各元素的值“value”,然后加上是否等于“”某些设定的内容,或者说本身固有的内容(比如EMAIL的)。按此你可以加以扩充它的功能,比如完善Email的检验功能,加上判断“”后的邮件服务器的地址和一点“.”。19.2.2 创建可重用的校验代码1、检查输入字符串是否为空或者全部都是空格function isNull( str )/ 输入strif ( str = ) return true;var reg

17、u = +$;var re = new RegExp(regu);return re.test(str);/ 返回:如果全是空返回true,否则返回false2、检查输入对象的值是否符合整数格式function isInteger( str ) / str 输入的字符串var regu = /-0,10-91,$/;return regu.test(str);/ 如果通过验证返回true,否则返回false3、检查输入手机号码是否正确function checkMobile( s ) /输入s字符串var regu =/130-99$/;var re = new RegExp(regu);if

18、 (re.test(s) return true;elsereturn false;/如果通过验证返回true,否则返回false4、检查输入对象的值是否符合E-Mail格式function isEmail( str ) /输入str的字符串var myReg = /-_A-Za-z0-9+(_A-Za-z0-9+.)+A-Za-z0-92,3$/; if(myReg.test(str) return true; return false; /返回:如果通过验证返回true,否则返回false5、检查输入字符串是否只由英文字母和数字和下划线组成function isNumberOr_Lette

19、r( s )/ 输入s字符串var regu = 0-9a-zA-Z_+$;var re = new RegExp(regu);if (re.test(s) return true;elsereturn false;/如果通过验证返回true,否则返回false6、判断是否是日期实例19-4 判断日期程序内容如下:function isDate( date, fmt ) /输入:date:日期;fmt:日期格式if (fmt=null) fmt=yyyyMMdd;var yIndex = fmt.indexOf(yyyy);if(yIndex=-1) return false;var year

20、 = date.substring(yIndex,yIndex+4);var mIndex = fmt.indexOf(MM);if(mIndex=-1) return false;var month = date.substring(mIndex,mIndex+2);var dIndex = fmt.indexOf(dd);if(dIndex=-1) return false;var day = date.substring(dIndex,dIndex+2);if(!isNumber(year)|year2100 | year12 | monthgetMaxDay(year,month) |

21、 day 01) return false;return true;/返回:如果通过验证返回true,否则返回falsefunction getMaxDay(year,month) if(month=4|month=6|month=9|month=11)return 30;if(month=2)if(year%4=0&year%100!=0 | year%400=0)return 29;elsereturn 28;return 31;19.3 事件响应19.3.1 事件处理的基本概念 事件是浏览器响应用户交互操作的一种机制,JavaScript的事件处理机制可以改变浏览器响应用户操作的方式,这

22、样就开发出具有交互性,并易于使用的网页。浏览器为了响应某个事件而进行的处理过程,叫做事件处理。事件定义了用户与页面交互时产生的各种操作,例如单击超级连接或按钮时,就产生一个单击(click)操作事件。浏览器在程序运行的大部分时间都等待交互事件的发生,并在事件发生时,自动调用事件处理函数,完成事件处理过程。 事件不仅可以在用户交互过程中产生,而且浏览器自己的一些动作也可以产生事件,例:当载入一个页面时,就会发生load事件,卸载一个页面时,就会发生unload事件等。归纳起来,必需使用的事件有三大类: 引起页面之间跳转的事件,主要是超连接事件。 事件浏览器自己引起的事件。 事件在表单内部同界面对

23、象的交互。 19.3.2 JavaScript事件处理器1.onblur事件当一个对象失去焦点时,blur事件被触发。2.onchange 事件发生在文本输入区的内容被更改,然后焦点从文本输入区移走之后。捕捉此事件主要用于实时检测输入的有效性,或者立刻改变文档内容。3.onclick 事件发生在对象被单击的时候。单击是指鼠标停留在对象上,按下鼠标键,没有移动鼠标而放开鼠标键这一个完整的过程。4.onfocus 事件发生在一个对象得到焦点的时候。5.onload 事件发生在文档全部下载完毕的时候。全部下载完毕意味着不但 HTML 文件,而且包含的图片,插件,控件,小程序等全部内容都下载完毕。本事

24、件是 window 的事件,但是在 HTML 中指定事件处理程序的时候,我们是把它写在标记中的。6.onmouseout 事件发生在鼠标离开对象的时候。参考 onmouseover 事件。 7.onmouseover 事件发生在鼠标进入对象范围的时候。这个事件和 onmouseout 事件,再加上图片的预读,就可以做到当鼠标移到图像连接上,图像更改的效果了。有时我们看到,在指向一个连接时,状态栏上不显示地址,而显示其它的资料,看起来这些资料是可以随时更改的。它们是这样做出来的:19.3.3 出错处理1.onerror事件处理函数它是第一个用来协助JavaScript处理错误的机制。页面上出现异

25、常时,error事件便在window对象上触发。实例19-5 错误事件程序内容如下:onerror例子window.onerror=function()alert(发生错误!);在上述代码中,在页面载入时尝试调用不存在的函数,此时会引发一个异常。弹出“发生错误”的错误信息。但是,浏览器的错误信息也显示出来了,如何在浏览器上隐藏它呢,只需onerror方法返回一个true即可。window.onerror=function()alert(“发生错误!”);returntrue;2.取出错误信息onerror处理函数提供了三种信息来确定错误确切的性质:i)错误信息对于给定错误,浏览器会显示同样的信息;ii)URL在哪个文件中发生了错误;行号给定URL中发生错误的行号。访问方法见如下例子:window.onerror=function(sMessage,sUrl,sLine)alert(发生错误!n+sMessage+nURL:+sUrl+nLineNumber:+sLine);returntrue;3.处理语法错误onerror还能处理语法错误。但有一点必须注意,事件处理函数必须是页面中第一个出现的代码,因为如果语法错误出现在设置事件处理函数之

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1