1.js数字-NaN和Infinity

1、在js中,有一种特殊的数值,叫做NaN(Not a Number),表示本来要返回数值的操作却未返回数值的情况,例如0除以0的操作,在其它语言中会报错误或异常,而在js中,0/0会返回NaN,不中断代码执行。

0/0;  //NaN

2、任何涉及NaN的运算都会返回NaN,例如

1 + 0/0; //NaN

3、NaN与任何值都不相等,包括自身,例如

console.log(NaN == NaN);  //false

js提供了isNaN方法用来判断是否是NaN,如

isNaN(0/0);  //true

4、Infinity用于表示正无穷大,- Infinity用于表示负无穷大,例如:

1/0;  //Infinity
-1/0; //-Infinity

5、Infinity与Nan

Infinity * 0;  //NaN
1、0/0返回NaN
2、1/0返回Infinity
3、Infinity*0返回NaN
4、NaN参与运算都返回NaN
5、NaN不等于NaN
6、用isNaN判断是否为NaN 二.js类型-字符串

1、在js中,字符串可以用单引号(’)或双引号(’’)表示,例如

var str1 = 'hello', str2 = "hello";
  • 单引号中带双引号

  • 双引号中带双引号

  • 双引号中带双引号

var str = 'hello,  "张三"';
console.log(str); str = "hello, '张三'";
console.log(str); str = "Hello, \"张三\"";
console.log(str);
四、直接量

1、可以在程序中直接使用的数据值,叫直接量。
如:

12 //表示是数字
1.2 //表示是小数
"hello world" //表示字符串
'Hello' //表示字符串
true/flase //表示布尔值
null //空值
{a:1,b:2} //表示对象
[a,b,c,d,e] //表示数组
五、字符串使用

1、使用“+”运算符可以将字符串拼接在一起。

var a = "Hello" +"world!";

2、String是一个内置的对象,此对象提供了许多可以调用的常用方法。

var s = "hello javascript";
s.charAt(0);//返回第一个字符
s.charAt(s.length -1); //返回最后一个字符
s.substring(1,4);//取子串
s.indexOf("o");//返回该字符出现的位置
s.lastIndexOf("a");//返回最后一次字符出现位置
s.split(" ");//返回按空格分割成的数组字符
s.replace("h","H");//字符替换
s.toUpperCase();//字符串转成大写

注意:字符串是固定不变的,字符串方法都返回新的字符串。

六、js的全局对象

1、当js解释器启动时(或浏览器加载新页面时),将创建一个新的全局对象,并给它一些初始属性:

全局属性:

  • undefined :未定义值
  • Infinity :正的无穷大
  • NaN : 值是不是数字值

全局函数:’

  • isNaN() : 判断是否是非数字值。
  • eval() : 将字符串当作脚本代码来执行
  • parseFloat() :解析字符串并返回浮点数
  • parseInt() :解析字符串并返回整数
  • decodeURI(): 解码URI
  • encodeURI() : 将字符串编码
  • String():转换为字符串
  • Number():转换为数字
  • Date():转换为日期

2、可以用this关键字引用全局对象。

var g = this;
console.log(isNaN());
console.log(parseInt("")+);
console.log(parseFloat("123.11"));
var url = encodeURI("http://www.itbegin.com/it学习/");
console.log(url);//编码后空格、中文会转码
console.log(decodeURI(url));
console.log(String("abc"));
console.log(Number("123.11")+);
var s = parseInt("123.11")+;
console.log(s);
var global = this;//定义了引用全局对象的全局变量
console.log(global.parseInt(""));
八、显式类型转换

1、js里很多是自动做类型转换。

var a = 1;//a的类型的数字
a = "abc";//这里a的类型变为字符型

2、显式转换,可以让代码可读性更强。

var a = Number("3");
var s = String(false);
var b = Boolean([]);

3、js里某些运算符会做隐式的类型转换。

var a = 1;
a+"";//此表达式就会转换为字符串
console.log(Number(""));//字符串转数字
console.log(String(false));//布尔值转字符串
var b = Boolean("false");
console.log(b);//字符串转布尔值 var n = ;
console.log(n.toString());//数字转字符串
console.log(n.toString());//数字转二进制字符串 console.log(parseInt("112 abc112"));//尽可能的解析数字字符,并忽略后面的内容。
console.log(parseFloat("3.55 abc"));
console.log(parseFloat(".1"));
console.log(parseInt("0.1"));
console.log(parseInt(".1"));
console.log(parseFloat("$88.12"));

一、核心JavaScript内置对象,即ECMAScript实现提供的不依赖于宿主环境的对象

这些对象在程序执行之前就已经(实例化)存在了。ECMAScript称为The Global Object,分为以下几种

1, 值属性的全局对象(Value Properties of the Global Object)。有NaN,Infinity,undefined。

2, 函数属性的全局对象(Function Properties of the Global Object)。有eval,parseInt,parseFloat,isNaN,isFinite,decodeURI,encodedURI,encodeURIComponent

3,构造器(类)属性的全局对象(Constructor Properties of the Global Object)。有Object,Function,Array,String,Boolean,Number,Date,RegExp,Error,EvalError,RangeError,ReferenceError,SyntaxError,TypeError,URIError。

4,其它属性的全局对象(Other Properties of the Global Object),可以看出成是Java中的静态类,可以直接用类名+点号+方法名使用。有Math,JSON。

ECMAScript规范提到这些全局对象(The Global Object)是具有Writable属性的,即Writable为true,枚举性(Enumerable)为false,即不能用for in枚举。ECMAScript有这么一段

Unless otherwise specified, the standard built-in properties of the global object have attributes {[[Writable]]: true, [[Enumerable]]: false, [[Configurable]]: true}.




表达式

1、最简单的表达式是“原始表达式”,它包括常量或直接量、关键字和变量。

var b = 1.1;
var s = "itbegin";

2、对象初始化表达式实际是用来新创建的对象。

var obj = {a:1,b:2};

3、数组初始化表达式实际是用来新创建一个数组。

var a = [];
var b = [1,2,3];
var c = [1,,4];//数组4个元素,其中两个是undefined

4、函数定义表达式,用来定义一个新的函数。

var area = function(r){return 3.14*r*r;}//圆面积函数

5、属性表达式,通过“.”符号来访问对象的属性。

var o = {a:1,b:1};
o.a;//表达式o的a属性
o.b;//表达式o的b属性

6、调用表达式是一种调用函数或方法的语法。

f();//调用函数f(


Day03——类、值和对象的更多相关文章

  1. java匿名类和匿名对象及this的其他用法

    /* 匿名内部类:就是内部类的简写格式. 必须前提:内部类必须继承或者实现一个类或者接口. 匿名内部类其实就是一个匿名 子类对象. 格式:new 父类对象 or 接口(){ 子类内容:(覆盖父类的, ...

  2. Scala伴生类和伴生对象

    单例对象与类同名时,这个单例对象被称为这个类的伴生对象,而这个类被称为这个单例对象的伴生类.伴生类和伴生对象要在同一个源文件中定义,伴生对象和伴生类可以互相访问其私有成员.不与伴生类同名的单例对象称为 ...

  3. Ognl值栈对象及struts标签

    用户每次访问struts的action,都会创建一个Action对象.值栈对象.ActionContext对象:然后把Action对象放入值栈中: 最后再把值栈对象放入request中,传入jsp页面 ...

  4. python 全栈开发,Day18(对象之间的交互,类命名空间与对象,实例的命名空间,类的组合用法)

    一.对象之间的交互 现在我们已经有一个人类了,通过给人类一些具体的属性我们就可以拿到一个实实在在的人.现在我们要再创建一个狗类,狗就不能打人了,只能咬人,所以我们给狗一个bite方法.有了狗类,我们还 ...

  5. python的类和实例化对象

    一切皆对象,类也是对象,类来自于元类type,如果一个类没有声明自己的元类,默认它就是元类. 即类是元类的实例,通过type(类)会显示type,而实例来自于类. 类有两个属性,数据属性和函数属性,下 ...

  6. Struts2_day03--课程安排_OGNL概述入门_什么是值栈_获取值栈对象_值栈内部结构

    Struts2_day03 上节内容 今天内容 OGNL概述 OGNL入门案例 什么是值栈 获取值栈对象 值栈内部结构 向值栈放数据 向值栈放对象 向值栈放list集合 从值栈获取数据 获取字符串 获 ...

  7. python中如何统计一个类的实例化对象

    类中的静态变量 需要通过类名.静态变量名 来修改 :通过对象不能修改 python中如何统计一个类的实例化对象?? class Person: #静态变量count,用于记录类被实例化的次数 coun ...

  8. C 和 C++ 的标准库分别有自己的 locale 操作方法,C 标准库的 locale 设定函数是 setlocale(),而 C++ 标准库有 locale 类和流对象的 imbue() 方法(gcc使用zh_CN.GBK,或者zh_CN.UTF-8,VC++使用Chinese_People's Republic of China.936或者65001.)

    转自:http://zyxhome.org/wp/cc-prog-lang/c-stdlib-setlocale-usage-note/ [在此向原文作者说声谢谢!若有读者看到文章转载时请写该转载地址 ...

  9. day21——面向对象初识、结构、从类名研究类、从对象研究类、logging模块进阶版

    day21 面向对象的初识 面向对象第一个优点: 对相似功能的函数,同一个业务下的函数进行归类,分类. 想要学习面向对象必须站在一个上帝的角度去分析考虑问题. 类: 具有相同属性和功能的一类事物. 对 ...

  10. 类属性与对象实现,init方法的作用,绑定方法,绑定方法与普通函数的区别,继承,抽象与继承,派生与覆盖

    今日内容: 1.类属性与对象属性 2.init方法的作用 3.绑定方法 4.绑定方法与普通函数的区别(非绑定方法) 5.继承 6.抽象与继承 7.派生与覆盖 1.类属性与对象属性 类中应该进存储所有对 ...

随机推荐

  1. tomcat Server.xml Context配置

    有时候需要在tomcat里面做特殊的配置,来进行访问: 例如你的程序 名字是hello端口是80  这时候你要访问你的程序 就要用 localhost/hello 来访问了. 但是怎么直接用 loca ...

  2. Bullet_Point_Py

    1. if __name__ == "__main__" Term: 模块最高级的代码:模块中没有缩进的代码 Principal 1: 第一次导入模块会执行模块最高级的代码.不管你 ...

  3. 哈密顿圈~Lingo程序

    sets: c/1..15/:u; link(c,c):w,x; endsets data: w=@ole('第二题第一组.xls','d'); enddata n=@size(c); min=@su ...

  4. 移动前端不得不了解的HTML5 head 头标签(中上篇)

    Meta 标签 meta标签是HTML中head头部的一个辅助性标签,它位于HTML文档头部的 <head> 和 <title> 标记之间,它提供用户不可见的信息.虽然这部分信 ...

  5. chrome浏览器调试工具的使用

    废话不多说,给大家介绍一下最基本的浏览器调试工具

  6. Apriori算法-数组-C语言

    原文地址:http://blog.csdn.net/liema2000/article/details/6118423 #include<stdio.h>typedef struct { ...

  7. 如何更改mysql可执行路径及更改mysql数据库文件路径

    一.如何更改服务中MySQL的可执行文件路径: 解决方法:到注册表里HKEY_LOCAL_MECHINE---SYSTEM ---CurrentControlSet 更改查找一. MySQL项值,然后 ...

  8. 样式的操作-不同浏览器加载不同的css文件

    ———————————————————— <script type="text/javascript">            //body加载事件监听函数       ...

  9. RESTful架构1--架构理解

    转自:理解RESTful架构 越来越多的人开始意识到,网站即软件,而且是一种新型的软件. 这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时( ...

  10. LeetCode OJ 257. Binary Tree Paths

    Given a binary tree, return all root-to-leaf paths. For example, given the following binary tree: 1 ...