《javascript高级编程》读书笔记(两)javascript基本概念

《javascript高级编程》读书笔记(两)javascript基本概念

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

第三章:基本概念

ECMAScript那里5种简单数据类型(也称基本数据类型):Undefined\Null\Boolean\Number\String,另一种复杂数据类型——Object,Object本质上是由一组无序的名值对组成的。

typeof是一个操作符而不是函数.

Undefined类型:此类型仅仅有一个值,undefined.在使用var声明变量但未对其初始化时。这个变量的值就是undefined.

var message

var message2 = undefined;

alert(message);                   //  ”undefined”

alert(message == undefined);       //  true

alert(typeof message);            //  ”undefined”

alert(message == undefined);       //  true

alert(age);                     //   产生错误

alert(typeof age);               //  ”undefined”

 

Null类型:此类型仅仅有一个值,null.表示一个空对象指针。

var car = null;    

alerttypeof car;        //     ”object”

if(car != null){

   //car对象运行操作

}

undefined值是派生自null值的。

alert(null == undefined);      //true

仅仅要意在保存对象的变量还没有真正保存对象,就应该明白地让该对象保存null值。

Number类型:

  八进制的第一位是0,十六进制的前两位是0x.

  科学计数法:e

ECMAScript所能表示的最小和最大的值各自是:Number.MIN_VALUENumber.MAX_VALUE,超出范围。会被成Infinity值(即Number.POSITIVE_INFINITY)或者Infinity(即Number.NEGATIVE_INFINITY.

NaNNot a Number

1. 不论什么涉及到NaNde 操作都会返回NaN.

2. NaN与不论什么值都不相等,包含NaN本身

 alert NaN == NaN ;    //  false

 IsNaN()在接受到一个值之后,会尝试将这个值转换为数值。

alert(isNaN(NaN));              //true

alert(isNaN(10));              //false

alert(isNaN(“10”));              //false

alert(isNaN(“blue”));              //true

alert(isNaN(true));              //false(能够被转换成1)

isNaN也适用于对象,会先调用对象的valueOf()方法,假设不能转换为数值。再基于返回值调用toString()方法。

数值转换:

能够将非数值转换成数值的函数:

1. Number()   用于不论什么数据类型,不解析八进制

var str ;

var str2 = null;

var str3 = “hello world”;

Number(str);        //NaN

Number(str2);       //0

Number(str3);       //NaN

Number(“”);        //0

Number(“000011”);  //11

Number(true);      //1

Number(“0xA”);     //10

一元加操作符的操作与Number()同样。

2. parseInt()  用于字符串类型(忽略前面的空格),可解析八进制

parseInt(“   1234blue”);         // 1234

parseInt(“”);                   // NaN

parseInt(“0xa”);                // 10

parseInt(22.5);                 //22

parseInt(“70”,8);               //56  (指定基数。即8进制)

parseInt(“10”,2);             // 2

3. parseFloat()  用于字符串类型(忽略前面的空格),仅仅解析10进制

parseFloat(“1234blue”);                //1234

parseFloat(“0xA”);                    //0

parseFloat(“22.34.5”);                 //22.34

parseFloat(“0908.5”);                 //908.5

parseFloat(“3.125e7”);                //31250000

String类型:能够用双引號。也能够用单引號表示。

 除了nullundefined值没有toString(),其它都有。可是nullundefined能够调用String(),返回对应的字符串。即null值返回“null”,undefined值返回“undefined”

 toString()能够传入基数參数,表示输出的进制表示。如:

  var num = 10;

  number.toString(2);   // “1010”

  要把某个值转换为字符串,能够使用加号操作符把它与一个空字符串(””)加在一起。

with语句:

 with语句的作用是将代码的作用域设置到一个特定对象中。目的是简化多次编写同一个对象的工作。样例见···

可是大量使用with语句会导致性能下降,同一时候也会给调试代码造成困难。因此在开发大型应用程序时,不建议使用with语句。

switch语句:

switch语句在比較值时使用的是全等操作符。因此不会发生类型转换(比如。字符串“10”不等于数值10.

函数的返回值:

 除了return语句外。没有不论什么声明表示该函数返回一个值。

另外。return语句也能够不带不论什么返回值,此时,函数在停止运行后将返回undefined

ECMAScript的函数參数:重点

命名的參数仅仅提供便利,但不是必须的。解析器不会验证命名參数。

ECMAScript中的參数在内部是一个数组来表示的。能够通过arguments对象来訪问这个參数数组,从而訪问每个參数。

改动arguments对象中的值会自己主动反映到相应的命名參数。可是改动命名參数不会改变arguments相应的值。

没有传递值得命名參数将自己主动被赋予undefined值。

ECMAScript中的全部參数传递的都是值,不可能通过引用传递參数。

ECMAScript功能不能超载,您可以覆盖。

版权声明:本文博主原创文章。博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117061.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python lambda表达式及用法_Python lambda表达式及用法

    python lambda表达式及用法_Python lambda表达式及用法lambda表达式是现代编程语言争相引入的一种语法,如果说函数是命名的、方便复用的代码块,那么lambda表达式则是功能更灵活的代码块,它可以在程序中被传递和调用。回顾局部函数get_math_func()函数将返回三个局部函数之一。该函数代码如下:defget_math_func(type):#定义三个局部函数…#返回局部函数iftype==”square”:retu…

    2022年10月18日
    0
  • 【汇编语言】(x86)test与跳转指令(je jle jge jg jl……)组合的含义

    【汇编语言】(x86)test与跳转指令(je jle jge jg jl……)组合的含义在x86指令集中,经常遇到text指令与条件跳转指令组合,这是什么含义呢?博主表示,查了很多资料也没人完全说清楚……这里只用最简单的,抽象层次进行说明,不讲原理。举例text edx,edxjle 某地址含义是:如果edx<=0,就跳到某地址,否则继续往下执行。jle换成jg的话,就是edx>0跳转。其他同理。与cmp指令和跳转指令组合的区别是:这个组合比较的是cmpA,B中,A与B的关系。而textA,A则比较的是A与0的关系。这些都是抽象层次的应

    2025年6月25日
    1
  • IIC总线协议详解[通俗易懂]

    转自:https://www.cnblogs.com/aaronLinux/p/6218660.html1 I2C总线物理拓扑结构     I2C总线在物理连接上非常简单,分别由SDA(串行数据线)和SCL(串行时钟线)及上拉电阻组成。通信原理是通过对SCL和SDA线高低电平时序的控制,来产生I2C总线协议所需要的信号进行数据的传递。在总线空闲状态时,这两根线一般被上面所接的上拉电阻…

    2022年4月14日
    70
  • JQ-checkbox实现单选功能

    JQ-checkbox实现单选功能<divstyle=”line-height:1.5em;padding:5px0;font-size:14px;”><ulclass=”mui-table-view”><liclass=”mui-input-row”><inputtype=”checkbox”name=”quesA”id=”quesA”value=”…

    2022年5月30日
    34
  • 运行时常量池与字符串常量池_string字符串常量池

    运行时常量池与字符串常量池_string字符串常量池文章目录一、概念1、Class常量池(ClassConstantPool)1.1、常量池中数据项类型2、字符串池(StringPool、StringLiteralPool)2.1、参考文章:3、运行时常量池(RuntimeConstantPool)4、总结二、方法区的class文件信息,class常量池和运行时常量池的三者关系2.1、三者关系图:2.2、方法区class文…

    2022年9月9日
    0
  • MySQL 添加索引,删除索引及其用法[通俗易懂]

    MySQL 添加索引,删除索引及其用法[通俗易懂]原文:https://www.cnblogs.com/zz-tt/p/6609828.html一.索引的作用一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重。在数据量和访问量不大的情况下,mysql访问是非常快的,是否加索引对访问影响…

    2022年6月2日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号