JavaScript 学习笔记(一)
1.javascript中,值包括原始值和对象,原始值包括布尔值、数字、字符串、null和undefined,其他的值为对象。
原始值的特点:(1)按值进行比较:3===3> true; 'abc'==='abc'> true
(2)属性不能改变、添加和移除 var src='abc'; str.length=1; str.length> 3 str.foo=3; str.foo> undefined
对象:包括简单对象、数组、正则表达式,特点:(1)按引用进行比较 {}==={}> false var obj1={}; var obj2=obj1; obj1===obj2> true
(2)属性可以自由被改变、添加和移除 var obj={}; obj.foo=123; obj.foo> 123
2. undefined:没有值,未被初始化的变量即为undefined,丢失的参数,访问不存在的属性
null:没有对象,表示空值
undefined和null没有属性,也没有方法, 可被看做false
3. 对值分类:typeof和instanceof
typeof主要用于原始值,instanceof主要用于对象
typeof undefined> 'undefined' typeof null> object ,但是null不是一个对象
null instanceof object> false undefined insteanceoof object> false
4. 被解释为false的值:undefined、null、false、0、NaN、'' ,其他值被解释为true
5. &&:可以返回布尔值,也可为其他值,如果第一个运算数是假的,返回它,否则返回第二个运算数 NaN&&'abc'> NaN 123&&'abc'> 'abc'
||: 可以返回布尔值,也可为其他值,如果第一个运算数是真的,返回它,否则返回第二个运算数 'abc'||123> 'abc' ''||123> 123
6. 所有的数字都是浮点数 1===1.0> true, 还有特殊的数字:NaN,Infinity, Infinity比任何数字大(除了NaN),-Infinity比任何数小(除了NaN)
7. 函数声明具有提升特性—它们的实体会被移动到所在作用域的开始处。这使得我们可以引用后面声明的函数。
function foo(){
bar(); //Ok
function bar(){
}
}
注意,var 声明赋值不具备该特性,
function foo(){
bar(); //Not OK
var bar=function(){
}
}
8. 函数内的arguments不是数组,只是类似数组,有length属性,可以通过[]访问每个参数,但是不能对它调用数组的方法, 可以通过toArray()方法将它变为数组
9. 一个变量的作用域总是完整的函数:
function foo(){
var x=-1;
if(x<0)
{
var tmp=-x;
}
console.log(tmp); //
}
10. 所有的变量声明都会被提升,声明会被移动到函数的开始处,而赋值还在原来的位置进行
function foo(){
console.log(tmp);// undefined
if(false)
{
var tmp=3;
}
}
11. 闭包:每个函数和它周围的变量保持着连接,哪怕离开被创建时的作用域也是如此。函数以及它所连接的周围作用域中的变量即为闭包。
function foo(s){
return function(){
s++;
return s;
}
}
var inc=foo(5);
inc();//
inc();//
inc();//
12. IIFE模式(立即调用表达式):引入新的作用域 , 防止一个变量变成全局变量
(function(){ //开启IIFE
var tmp=...;// 非全局变量
}());
用例:解决闭包造成的无意共享
result=[];
for(var i=0;i<5;i++)
{
(function(){
var i2=i; //复制i
result.push(function(){ return i2}); }();) } console.log(result[1]());//
console.log(result[3]());//
13. 两种面向对象机制:单一对象和构造函数
对象可以认为是一组属性的集合,使用in 运算符检查属性是否存在,使用delete运算符移除属性
任意属性名:使用引号括起来,用方括号获取和设置
var obj={'not a identifier': 123};
>obj['not a identifier']
123
>obj['not a identifier']=456;
//方括号可以动态计算
>obj['not a'+'identifier']
123
14. var func2=obj.func.bind(obj); //使用bind()方法提取一个对象中的方法
JavaScript 学习笔记(一)的更多相关文章
- Java程序猿的JavaScript学习笔记(汇总文件夹)
最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...
- Java程序猿的JavaScript学习笔记(8——jQuery选择器)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿JavaScript学习笔记(2——复制和继承财产)
计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...
- Java程序猿的JavaScript学习笔记(3——this/call/apply)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿JavaScript学习笔记(4——关闭/getter/setter)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- Java程序猿JavaScript学习笔记(14——扩大jQuery UI)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- JavaScript学习笔记之数组(二)
JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...
- JavaScript学习笔记[0]
JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...
- Java程序猿的JavaScript学习笔记(1——理念)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
随机推荐
- NGUI BUG /各种坑
以下为:NGUI3.6具体使用过程中碰到的 各种BUG /各种坑 备忘 1.UIToggle 使用UIToggle组件实现多个tab标签互斥,如果是在代码中动态的设置显示某个tab标签对应的内容,则需 ...
- gulp LiveReload middleware
用yo搭建的angular项目,用gulp自动化构建. 自动化构建主要的功能大致有: 1. 文件压缩 2. 文件重命名 3. 文件合并 4. css,js文件自动引入到html 5. 自动刷新 ... ...
- Ubuntu 14.04 server ssh 远程服务遇到的一点事儿
ubuntu server 14.04 root@ubuntu:/# lsb_release -aNo LSB modules are available.Distributor ID: Ubuntu ...
- tinymce整合struts2使用
在提交之前记得 instance.post(); 这个应付老师检查还是可以的,但是很详细的怎么具体使用,还是要去看官方文档. <%@ page language="java" ...
- CMakeLists for tesseract
在网上找了很多,直接用都不行,试了半天的到以下的结果. cmake_minimum_required(VERSION 2.8) project( test ) include_directories ...
- break continue.
1.break与continue.这两个关键字一般放在循环的花括号里面使用.break——结束整个循环.continue——结束本次循环,进入下次循环. 2.while循环 //初始条件 while( ...
- java: R文件重复
导入eclipse工程到intellij里面, 然后出现各种错误, xxx.R文件重复, 各种资源id在R文件中找不到, 后来发现是intellij默认将整个项目以及gen文件夹作为源代码目录了, 在 ...
- C、C++、Java、go的语法区别
详细C++.Java比较:http://www.cnblogs.com/stephen-liu74/archive/2011/07/27/2118660.html 一.C.C++的区别 在很大程度上, ...
- .Net MVC+bootstrap Table学习
一.效果展示 二.使用方法 1).相关css和js的引用 <link href="~/Themes/Bootstrap/css/bootstrap.css" rel=&quo ...
- Maven web项目三种运行方式
http://www.micmiu.com/software/build/maven-web-eclipse-deploy/