Sorry,前两张介绍的主题还是JavaScript,而第一章介绍了JavaScript和ECMAScript区别,所以前两章介绍的主题应该改为ECMAScript,但是

标题就不改了因为现在人们习惯性称之为JavaScript,所以以后的我会在内容中区分清楚。

好了,那我们这一次的主题就是ECMAScript的高级概念:

1、严格模式

  严格模式是在ECMAScript 5中引入的概念,目的是为ECMAScript中定义一种不同的解析和执行模型,来解决JS中的一些不严谨的行为如:

一条语句的后面没有加;等不严谨但是可用的行为。写法:

    在js文件的开头添加上"use strict";

    或者是在函数内部上方包含这条编译指令:

    function func(){

      "use strict";

    }

2、变量:

  (1)、在函数中使用var定义的变量都是局部变量,不用var定义的都是全局变量如:

  function func(){

    var temp = 0;

  }

  alert(temp);//出现错误

而:

  function func(){

    temp = 10;

  }

  alert(temp);// 10

所以我们在以后的项目编写中一定要注意,var这个占位符的使用。

  (2)、ECMAScript中的简单数据类型:Undefined,Null,Boolean,Number和String,还有一个复杂数据类型Object,

想查看所定义变量的数据类型,可以使用typeOf这个操作符,如 :

  typeOf(true)----boolean;//一下有一个boolean对正表。

  typeOf(10)------number;//

  typeOf(null)-----object;//null只是一个特殊指“null”,表示一个空对象指针,所以我们在声明一个对象的时候建议先给初始化null;var obj = null;

  typeOf(wang)---undefined;//只是一个特殊值"undefined",就是指变量被var声明但是没有初始化

  typeOf('wang')---string;

数据类型 转换为true的值 转化成false的值
String 任何非空字符串 ""(空字符串)
Number 任何非0数字包括无穷大 0或NaN
Object 任何不是Null的对象 null
     
     

  (3)、number:在所有基于IEEE754的数值的浮点计算,那么就不可以测试了和某个特定的浮点数相等,如:

  var a =0.1,b = 0.2;

  if(a+b == 0.3){//这种测试不要做,因为浮点小数想加在IEEE754中会产生误差。

    alert('a加b等于0.3');

  }

  isNaN()方法:可以检测参数是否可以转化为Number类型,并且NaN和任何数都不相等,所以不要用以下方法来判断放回是否为NaN

    var a = 3/0;

    if(a == NaN){//这种判断方式是不正确的

      alert('不合法');

    }

  Number();数值转化方法,规则太罗索了,给出几个例子把:

    Number(false);//0

    Number(null);//0

    Number(undefiined);//NaN

    Number("999xxx");//NaN

    Number("0xf");//15

    Number("abc");//NaN

  parseInt();处理整数,直接看例子:

    parseInt("1234bbb");//1234

    parseInt("");//NaN

    parseInt("0xA",16);//10,推荐使用parseInt的时候都加上转换使用的基数

    parseInt("AF");//NaN

    parseInt("AF",16)//175

  (4)、Object的属性和方法

    Constructor:保存着用于创建当前对象的函数

    hasOwnProperty(propertyName);用于检查指定的属性是否在当前的对象实例中,propertyName必须是以字符串格式出现

    isPrototypeOf(object);用于检查传入的对象是否是另一个对象的原型

    propertyIsEnumerable(propertyName);用于判断给定的属性是否可以用for-in的语句来便利

javascript 高级程序设计 三的更多相关文章

  1. JavaScript高级程序设计(三):基本概念:数据类型

    特别注意:ECMAScript是区分大小写的. 一.变量 1.ECMAScript的变量是松散型的.所谓松散型就是可以用来保存任何类型的数据.即每个变量仅仅是一个用于保存值的占位符而已.定义变量时要使 ...

  2. JavaScript高级程序设计(第三版)学习,第一次总结

    Array类型 var arr = []; arr.length; //返回数组元素个数 改变length可以动态改变数组大小 检测数组 instanceof可以检测某个对象是否是数组,限制:只能是一 ...

  3. JavaScript高级程序设计(第三版)学习笔记20、21、23章

    第20章,JSON JSON(JavaScript Object Notation,JavaScript对象表示法),是JavaScript的一个严格的子集. JSON可表示一下三种类型值: 简单值: ...

  4. 赠书《JavaScript高级程序设计(第三版)》5本

    本站微博上正在送书<JavaScript高级程序设计>走过路过的不要错过,参与方式,关注本站及简寻网+转发微博:http://weibo.com/1748018491/DoCtp6B8r ...

  5. 《JAVASCRIPT高级程序设计》第三章

    <JAVASCRIPT高级程序设计>第三章主要讲述了这门语言的基础概念,内容多而浅,通过思维导图可以帮助我们很好的理清脉络. js函数使用function关键字来声明,以下是一个简单的例子 ...

  6. JavaScript高级程序设计学习(三)之变量、作用域和内存问题

    这次讲的主要是变量,作用域和内存问题. 任何一门编程语言,都涉及这三个. 变量,比如全局变量,局部变量等,作用域,也分全局作用域和方法作用域,内存问题,在java中就涉及到一个垃圾回收的问题,由于ja ...

  7. 《Javascript高级程序设计》阅读记录(三):第五章 上

    这个系列以往文字地址: <Javascript高级程序设计>阅读记录(一):第二.三章 <Javascript高级程序设计>阅读记录(二):第四章 这个系列,我会把阅读< ...

  8. JavaScript高级程序设计第三版.CHM【带实例】

    从驱动全球商业.贸易及管理领域不计其数的复杂应用程序的角度来看,说 JavaScript 已经成为当今世界上最流行的编程语言一点儿都不为过. JavaScript 是一种非常松散的面向对象语言,也是 ...

  9. 《Javascript高级程序设计》阅读记录(一):第二、三章

    <Javascript高级程序设计>阅读记录(一) 这个系列,我会把阅读<Javascript高级程序设计>之后,感觉讲的比较深入,而且实际使用价值较大的内容记录下来,并且注释 ...

随机推荐

  1. 利用monkey测试android,入门级用户可能遇见的错误及解决办法 【转】

    转自[http://blog.csdn.net/zm2714/article/details/7977930] 一.D:\android\android-sdk-windows\tools目录中没有a ...

  2. 微信小程序---picker

    picker 从底部弹起的滚动选择器,现支持五种选择器,通过mode来区分,分别是普通选择器,多列选择器,时间选择器,日期选择器,省市区选择器,默认是普通选择器. wxml: 普通选择器(mode = ...

  3. justify-content & align-items & align-content

    [justify-content & align-items & align-content] 三个属性均作用于container. justify-content用于控制main-a ...

  4. javascript学习笔记(一):基础、输出、注释、引用、变量、数据类型

    javascript脚本必须位于<script></script>之间,<script>标签可以位于<head>中,也可以位于<body>中 ...

  5. java根据wsdl调用webservice

    本方法参考 Java核心技术 卷二 (第八版) 中10.6.2节相关内容,特与大家分享,欢迎大家批评指教 <a href="http://www.webxml.com.cn/" ...

  6. 第二章 向量(e)起泡排序

  7. NumPy 迭代数组

    NumPy 迭代数组 NumPy 迭代器对象 numpy.nditer 提供了一种灵活访问一个或者多个数组元素的方式. 迭代器最基本的任务的可以完成对数组元素的访问. 接下来我们使用 arange() ...

  8. TOJ 3589 likaer的最长点距

    传送门:http://acm.tzc.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=3589 时间限制(普通/Jav a) ...

  9. jQuery之禁止Get请求缓存

    如果两次Get请求的URL完全一样,则IE浏览器会调用上次缓存的结果,不会发起新的Http请求. 解决办法:在URL最后面加上时间戳. jQuery全局设置禁止缓存 $.ajaxSetup({ cac ...

  10. 截图原理(二)——android自动化测试学习历程

    接上一篇(截图原理) 视频地址:http://study.163.com/course/courseLearn.htm?courseId=712011#/learn/video?lessonId=87 ...