1、数据类型:原始类型(primitive type) 和对象类型(object type)

原始类型包括数字、字符串和布尔值;
除数字、字符串、布尔值、null(空)、undefined(未定义),其它都属于对象类型。
也可以分为可变(mutable)类型和不可变(immutable)类型。数字、字符串、布尔值、null和undefined属于不可变类型。
2、
非数字值用NaN表示,函数isNaN()用于判断一个值是否是非数字,如果参数是NaN或非数字值,返回true。
函数isFinite()在参数不是NaN、Infinity(无穷大)、-Infinity(负无穷大)的时候返回true。
3、全局对象
包括全局属性(全局变量属于全局属性)、全局函数、构造函数、全局对象。
 全局函数如isNaN()、parseInt()等,构造函数如Date()、RegExp()、String(),
全局对象如Mah、JSON。
新页面加载时将会创建一个新的全局对象,并定义初始属性,如上。
4、包装对象
定义:存取字符串、数字或布尔值的属性时创建的临时对象称为包装对象。
null、undefined没有包装对象,访问它们的属性会造成一个类型错误。
字符串、数字和布尔值可以通过String()、Nmber()和Boolean()构造函数来显式的创建包装对象。
一般情况下,比如我们在访问字符串的属性时,都是通过 "." 操作符来访问,如下:
 
 
 
2
2
 
 
 
 
 
1
console.log("hello world".length);
2
console.log("this a string".indexOf("a"));
 
 
其实在调用这些方式或属性时js内部隐式的为我们创建了一个包装对象。如下:
 
 
 
2
2
 
 
 
 
 
1
console.log(new String("hello world").length);
2
console.log(new String("this a string").indexOf("a"));
 
 
隐式和显式的区别:
两者并不相等。如下:
 
 
 
4
4
 
 
 
 
 
1
var a1 = "test",
2
   a2=new String("test");
3
console.log(a1 == a2);//true
4
console.log(a1 === a2);//false
 
 
隐式创建的包装对象,在使用完后之后就会被抛弃了,如:
 
 
 
2
2
 
 
 
 
 
1
test.a = "hello"; //隐式创建包装对象,用完即时销毁
2
console.log(test.a); //undefined  新创建一个包装对象,未初始化
 
 
用处:
有的浏览器性能不是很好,比如说低版本IE,当频繁处理字符串、数字时,效率会很低。
所以有时不如直接显式创建包装对象,防止浏览器过多地创建隐式的包装对象,提升性能。
 
 
 
4
4
 
 
 
 
 
1
//不推荐使用种方法
2
var example = "this is a example";  
3
//推荐使用这种方法,提升性能。
4
var example2 = new String("this is a example");
 
 
5、类型转换
(1)显式类型转换
可以通过Boolean()、Number()、String()或Object()函数。
(2)对象转换为原始值
所以对象都继承了toString()和valueOf()两个转换方法。
对象到字符串的转换步骤
  • 如果对象具有toString()方法,则调用这个方法。如果它返回一个原始值,这个值转换为字符串。
  • 如果对象没有toString()方法,或者这个方法并不返回一个原始值,那么javascript会调用valueOf()方法,如果存在这个方法,javascript会调用它,如果它返回一个原始值,这个值转换为字符串。
  • 否则,javascript无法从toString()或valueOf()获得一个原始值,因此它将抛出一个类型错误异常。

对象到数字的转换步骤

    与对象到字符串转换做相同的事情,只是它会首先尝试使用valueOf()方法。
如果将对象和一个原始值比较,则转换遵循对象到原始值的转换方式进行。
(3)在做算术运算的时候,如果其中一个操作数是对象,javascript会将对象转换为原始值,不管得到的原始值是否直接使用,都不会进一步转换为数字或字符串。
如:
 
 
 
5
5
 
 
 
 
 
1
var now = new Date(); 
2
typeof(now + 1); //将日期转换为字符串 (字符串的拼接)
3
typeof(now - 1); //使用对象到数字的转换
4
now == now.toString() //true:隐式和显式的字符串转换
5
now > (now - 1) //将日期转换为数字(隐式)
 
 
默认情况下,日期对象在转换为原始值时,会优先使用toString()方法(隐式)。在对日期对象执行加法运算时,要显式的将日期对象转换为数字,才能运算。
6、作用域
(1)变量作用域
全局变量拥有全局作用域。
在函数体内,局部变量的优先级高于同名的全局变量。
(2)函数作用域
在函数内声明的所有变量在函数体内始终是可见的。
(3)属性变量
使用var声明一个变量时,创建的这个属性是不可配置的。无法通过delete运算符删除。
没有使用严格模式给一个未声明的变量赋值,javascript会自动创建一个全局变量,这种方式创建的变量是可配置属性,可以删除它们:
 
 
 
6
 
 
 
 
 
1
var trueval = 1; //声明一个全局变量
2
fakeval = 2; //创建一个全局变量
3
this.fackval2 = 3; //同上
4
delete trueval //false 变量没有被删除
5
delete fakeval //true 变量被删除
6
delete this.fackval2 //true 变量被删除
 
 
 

span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }.cm-searching {background: #ffa; background: rgba(255, 255, 0, .4);}.cm-force-border { padding-right: .1px; }@media print { .CodeMirror div.CodeMirror-cursors {visibility: hidden;}}.cm-tab-wrap-hack:after { content: ""; }span.CodeMirror-selectedtext { background: none; }.CodeMirror-activeline-background, .CodeMirror-selected {transition: visibility 0ms 100ms;}.CodeMirror-blur .CodeMirror-activeline-background, .CodeMirror-blur .CodeMirror-selected {visibility:hidden;}.CodeMirror-blur .CodeMirror-matchingbracket {color:inherit !important;outline:none !important;text-decoration:none !important;}.CodeMirror-sizer {min-height:auto !important;}
-->

li {list-style-type:decimal;}.wiz-editor-body ol.wiz-list-level2 > li {list-style-type:lower-latin;}.wiz-editor-body ol.wiz-list-level3 > li {list-style-type:lower-roman;}.wiz-editor-body blockquote {padding: 0 12px;}.wiz-editor-body blockquote > :first-child {margin-top:0;}.wiz-editor-body blockquote > :last-child {margin-bottom:0;}.wiz-editor-body img {border:0;max-width:100%;height:auto !important;margin:2px 0;}.wiz-editor-body table {border-collapse:collapse;border:1px solid #bbbbbb;}.wiz-editor-body td,.wiz-editor-body th {padding:4px 8px;border-collapse:collapse;border:1px solid #bbbbbb;min-height:28px;word-break:break-word;box-sizing: border-box;}.wiz-hide {display:none !important;}
-->

js权威指南学习笔记(一)类型、值和变量的更多相关文章

  1. js权威指南---学习笔记02

    1.JS只有函数作用域,没有块级作用域这个概念: 它有一个特性——声明提前:在同一个函数中不同位置声明的变量,都被提前在函数开始的时候,执行声明操作:在原先位置执行赋值操作: 2.声明的全局变量,相当 ...

  2. js权威指南---学习笔记01

    1.当函数赋值给对象的属性时,就变为了方法:2.被零整除不报错,只会返回无穷大(Infinity)或者负无穷大.例外:零除以零等于非数字(NaN).3.NaN与任何值都不相等! 4.Javascrip ...

  3. js权威指南学习笔记(四)对象

    1.创建对象 (1).通过对象直接量的方式创建 说明:对象直接量是由若干名/值对组成的映射表,名/值对中间用冒号分隔,名/值对之间用逗号分隔,整个映射表用花括号括起来. 如:       5 5   ...

  4. js权威指南学习笔记(二)表达式与运算符

    1.数组初始化表达式 数组直接量中的列表逗号之间的元素可以省略,这时省略的空位会填充undefined.如:       2 2           1 var arr = [1,,,,,6]; 2 ...

  5. js权威指南学习笔记(三)语句

    1.声明语句 如果用var声明的变量没有初始化,那么这个变量的值会被初始化为undefined. 函数声明语句的语法如下:       4 4           1 console.log(func ...

  6. JavaScript 权威指南-学习笔记(一)

    本文所有教程及源码.软件仅为技术研究.不涉及计算机信息系统功能的删除.修改.增加.干扰,更不会影响计算机信息系统的正常运行.不得将代码用于非法用途,如侵立删! ## JavaScript 权威指南-学 ...

  7. HTTP权威指南-学习笔记

    目录 HTTP权威指南-学习笔记 HTTP: Web的基础 URL与资源 HTTP报文 连接管理 HTTP结构 Web服务器 代理 缓存 集成点: 网关,隧道及中继 Web机器人 识别,认证与安全 客 ...

  8. 《JS权威指南学习总结》

    JS权威指南学习总结:http://www.cnblogs.com/ahthw/category/652668.html

  9. 《JS权威指南学习总结--开始简介》

    本书共分成了四大部分: 1.JS语言核心 2.客户端JS 3.JS核心参考 4.客户端JS核心参考 其中 <JS权威指南学习总结--1.1语法核心> 是:第一部分JS语言核心 各章节重点 ...

随机推荐

  1. 2016级算法第五次上机-B.Bamboo&APTX4844魔发药水

    Bamboo&APTX4844魔发药水 题意 "于是,Bamboo耐着性子,看巫师从袖子里掏出 M 瓶时光泉水和 K 粒绿色能量.每瓶时光泉水重量为 c ,生发效果为 l:每粒绿色能 ...

  2. mybatis的入门(二)

    上篇文章首先介绍了JDBC操作数据库的相关知识,并总结了JDBC操作数据存在的一些问题,那么这篇文章我们来介绍下mybatis的相关内容 一.mybatis的架构图 下面对上面的架构图详细说明下: 1 ...

  3. C# 连接Oracle 11g 无需安装Oracle客户端

    1.首先到Oracle网站上下载ODAC 下载地址1:http://download.csdn.net/detail/easyboot/9456476 下载地址2:http://www.oracle. ...

  4. UGUI Slider的onValueChanged事件

    在本文,你将学到如何将UGUI Slider的onValueChanged事件进行统一管理. using System; using UnityEngine; using UnityEngine.UI ...

  5. 12.2.0.1 restart环境执行root.sh 报 CLSRSC-400 错误

    问题描述: 在LINUX 7.5 的环境上安装12.2.0.1 Restart Grid环境,执行root.sh  报 CLSRSC-400 错误 错误如下: 解决办法: 1. 参考(文档ID 136 ...

  6. python小游戏开发关于pygame库的安装

    ---恢复内容开始--- 测试环境:运行环境 Window 10 64bit上运行 前提条件 python3.7(当前时间最新版本20181021)安装(记住安装路径如C:\application\p ...

  7. Revit二次开发_快速显示隐藏剖面框

    最近遇到一种状况需要经常切换剖面框的可见性,于是想将剖面框的显示与隐藏做成一个按钮,方便切换. 其他类似元素想做成快速切换可见性应该可以使用类似做法. 这次的隐藏对象是剖面框,所以我直接就隐藏元素了. ...

  8. 用.net 2.0(或.net 3.5)开发的程序在.net 4.0的环境中运行的解决方案

    引用:.NET2.0程序集无法在.net 4.0 中运行的解决方案 1. 原来是在.net 2.0 (VS2008)的环境下的程序,通过升级到.net 4.0 (VS2013)导致程序运行不了 提示需 ...

  9. 深入理解Solaris X64系统调用

    理解系统调用的关键在于洞悉系统调用号是联系用户模式与内核模式的纽带.而在Solaris x64平台上,系统调用号被保存在寄存器RAX中,从用户模式传递到内核模式.一旦进入内核模式,内核的sys_sys ...

  10. 计算F1Score

    计算F1Score predictions = pval < epsilon fp = sum((predictions == 1) & (y == 0)) fn = sum((pred ...