javascript中常用编程知识


Posted in Javascript onApril 08, 2013

1.null 与 undefined

* 从一个对象中获取某个属性,如果该对象及其 prototype 链 中的对象都没有该属性的时候,该属性的值为 undefined 。
* 一个 function 如果没有显式的通过 return 来返回值给其调用者的话,其返回值就是 undefined 。有一个特例就是在使用new的时候。
* JavaScript 中的 function 可以声明任意个形式参数,当该 function 实际被调用的时候,传入的参数的个数如果小于声明的形式参数,那么多余的形式参数的值为 undefined 。
* null为空对象,注意与空的对象({})的区别。
简单来说,对于所有变量,只要声明后还没有指定初始值 ,那么他就是undefined,如果是Object类型用来表示空引用的概念,那么就是用null来表示。

2.if 表达式

* Null总是为假(false)
* Undefined总是为假(false)
* Number+0,-0 或是 NaN 的时候为假,其它值为真
* String空字符串的时候为假,其它值为真
* Object总是为真(true)

3.Array

JavaScript 中的数组(Array)和通常的编程语言,如 Java 或是 C/C++ 中的有很大不同。在 JavaScript 中的对象就是一个无序的关联数组,而 Array 正是利用 JavaScript 中对象的这种特性来实现的。在 JavaScript 中,Array 其实就是一个对象,只不过它的属性名是整数,另外有许多额外的属性(如 length)和方法(如 splice)等方便地操作数组。

4.new 运算符

JavaScript 中并没有 Java 中的类(class)的概念,而是采用构造器(constructor)的方式来创建对象。在 new 表达式中使用构造器就可以创建新的对象。由构造器创建出来的对象有一个隐含的引用指向该构造器的 prototype 。

5.prototype

prototype是javascript原型继承的核心概念,大家一定在某个javascript类库里面见过 Array.prototype.push.call()这样的用法,所以归根结底prototype是一个对象。我们可以通过 prototype给native class添加一些有用的方法,也可以通过prototype实现继承。如果对prototype比较感兴趣,可以在ff里面通过__proto__来访 问指定对象的原型链。

6.scope chain

执行上下文(execution context)是 ECMAScript 规范中用来描述 JavaScript 代码执行的抽象概念。所有的 JavaScript 代码都是在某个执行上下文中运行的。在当前执行上下文中调用 function 的时候,会进入一个新的执行上下文。当该 function 调用结束的时候,会返回到原来的执行上下文中。如果 function 调用过程中抛出异常,并没有被捕获的话,有可能从多个执行上下文中退出。在 function 调用过程,也可能调用其它的 function,从而进入新的执行上下文。由此形成一个执行上下文栈。

注:如果对scope chain比较感兴趣,可以在ff里面通过__parent__属性来访问函数的scope chain,比较遗憾的是ff的js引擎SpiderMonkey对这个属性的支持不是很完美,出现内部函数的时候会出错,所以建议用Rhino (http://developer.mozilla.org/en/docs/Rhino)。

注:这里需要提的是注意函数表达式和函数声明对scope chain的影响。

7.closure

闭包也算是js比较常用的特色功能了,一般我们在java里面执行完毕的一个函数,内部变量将全部被回收,但在javascript中,我们可以通过某些方法,使执行完的函数的内部变量依然存在,并且可访问,这样就构成了一个闭包。

当然,什么东西都有两面性,闭包给我们带来好处的时候,也会带来不少的麻烦,比如一个不留神就产生了内存的泄漏,所以我们需要合理的应用这些技术。如果要 深入学习闭包,建议去看几个js library(prototype,jquery,mootools),里面有一些很经典的闭包应用,比如bind方法等,这里就不多赘述。

Javascript 相关文章推荐
用jquery实现点击栏目背景色改变
Dec 10 Javascript
jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate)
May 22 Javascript
jquery 页眉单行信息滚动显示实现思路及代码
Jun 26 Javascript
JQuery中DOM加载与事件执行实例分析
Jun 13 Javascript
JavaScript对象属性检查、增加、删除、访问操作实例
Jul 08 Javascript
关于JS中二维数组的声明方法
Sep 24 Javascript
利用JS屏蔽页面中的Enter按键提交表单的方法
Nov 25 Javascript
Vue监听数组变化源码解析
Mar 09 Javascript
js实现彩色条纹滚动条效果
Mar 15 Javascript
WdatePicker.js时间日期插件的使用方法
Jul 26 Javascript
vue.js声明式渲染和条件与循环基础知识
Jul 31 Javascript
jquery插件实现图片悬浮
Apr 16 jQuery
利用webqq协议使用python登录qq发消息源码参考
Apr 08 #Javascript
setInterval,setTimeout与jquery混用的问题
Apr 08 #Javascript
JQueryEasyUI Layout布局框架的使用
Apr 08 #Javascript
jquery 实现二级/三级/多级联动菜单的思路及代码
Apr 08 #Javascript
JQueryEasyUI datagrid框架的基本使用
Apr 08 #Javascript
Jquery中使用setInterval和setTimeout的方法
Apr 08 #Javascript
JQueryEasyUI datagrid框架的进阶使用
Apr 08 #Javascript
You might like
用PHP制作静态网站的模板框架(三)
2006/10/09 PHP
php表单提交问题的解决方法
2011/04/12 PHP
php动态实现表格跨行跨列实现代码
2012/11/06 PHP
PHP获取网页标题的3种实现方法代码实例
2014/04/11 PHP
php将HTML表格每行每列转为数组实现采集表格数据的方法
2015/04/03 PHP
escape、encodeURI、encodeURIComponent等方法的区别比较
2006/12/27 Javascript
JavaScript写的一个DIV 弹出网页对话框
2009/08/14 Javascript
JavaScript实现url地址自动检测并添加URL链接示例代码
2013/11/12 Javascript
JQuery解析XML数据的几个简单实例
2016/05/18 Javascript
JavaScript 过滤关键字
2017/03/20 Javascript
浅谈通过JS拦截 pushState和replaceState事件
2017/07/21 Javascript
Mobile Web开发基础之四--处理手机设备的横竖屏问题
2017/08/11 Javascript
vue checkbox 全选 数据的绑定及获取和计算方法
2018/02/09 Javascript
微信小程序时间标签和时间范围的联动效果
2019/02/15 Javascript
jQuery实现动态生成年月日级联下拉列表示例
2019/05/11 jQuery
JS array数组检测方式解析
2020/05/19 Javascript
numpy自动生成数组详解
2017/12/15 Python
python跳出双层for循环的解决方法
2019/06/24 Python
Win10下安装并使用tensorflow-gpu1.8.0+python3.6全过程分析(显卡MX250+CUDA9.0+cudnn)
2020/02/17 Python
python绘制动态曲线教程
2020/02/24 Python
完美解决ARIMA模型中plot_acf画不出图的问题
2020/06/04 Python
python3中TQDM库安装及使用详解
2020/11/18 Python
意大利香水和化妆品购物网站:Parfimo.it
2019/10/06 全球购物
ECHT官方网站:男女健身服
2020/02/14 全球购物
意大利时尚奢侈品店:D’Aniello Boutique
2021/01/19 全球购物
毕业生优秀推荐信
2013/11/26 职场文书
计算机专业毕业生自我鉴定
2014/01/16 职场文书
商场主管竞聘书
2014/03/31 职场文书
入职担保书怎么写
2014/05/12 职场文书
2014年干部作风建设总结
2014/10/23 职场文书
2014年乡镇团委工作总结
2014/12/18 职场文书
趵突泉导游词
2015/02/03 职场文书
军训个人总结
2015/03/03 职场文书
用Python制作灯光秀短视频的思路详解
2021/04/13 Python
python调试工具Birdseye的使用教程
2021/05/25 Python
css3中2D转换之有趣的transform形变效果
2022/02/24 HTML / CSS