ECMAScript一步一步创建自己的js类库(一):理解函数
2012-11-22 09:24
393 查看
ECMAScript中最有意思,最强大的地方在于函数。最进在完善自己的js类库的时候发现我们经常在用函数,但真的很少有人懂得ECMAScript函数功能。
1:什么是函数?
ECMAScript函数其实就是对象,每个函数都是Function类型的实例而且有属性和方法,由于函数是对象,函数名其实就是指向函数对象的指针,不会与某个函数绑定。
2:创建函数的方法
3:函数声明和函数表达式的不同
ECMAScript对函数声明和函数表达式的解析并非一视同仁,解析器会先读取函数声明,并使其在任何代码前都可用。
例:
函数表达式为执行到这一行才解析器才会解析
4:理解this属性
this 属性是我们经常用的属性,其行为与Java,C#,PHP大致类似。
5:创建自己的类库插件
简单的介绍了下函数,对于理解函数这些内容远远不够,例如构造函数模式,原形模式,原形链等等都是要花很多时间去理解。
创建类
类库大致的框架构建完成,这样我们创建类可以调用extended方法,创建实例可以调用include方法。下一章节会在此基础上扩展更多功能,基于原型给“类”添加继承。
1:什么是函数?
ECMAScript函数其实就是对象,每个函数都是Function类型的实例而且有属性和方法,由于函数是对象,函数名其实就是指向函数对象的指针,不会与某个函数绑定。
2:创建函数的方法
(1):function Person(name) { return name; } (2):var Person=function(name) { return name; } (3):var Person=new function(“name”,”return name”);(不推荐使用,ECMAScript会解析两次所以不推荐使用)
3:函数声明和函数表达式的不同
ECMAScript对函数声明和函数表达式的解析并非一视同仁,解析器会先读取函数声明,并使其在任何代码前都可用。
例:
assert(false); function assert(value, msg) { if (!value) { alert (msg || (value + " does not equal true")); } }
函数表达式为执行到这一行才解析器才会解析
如:assert(false); var assert= function (value, msg) { if (!value) { alert (msg || (value + " does not equal true")); } }
4:理解this属性
this 属性是我们经常用的属性,其行为与Java,C#,PHP大致类似。
如:window.name=’用未来思考现在’; window.name = "用未思考现在; showName(); function showName() { alert(this.name); }
5:创建自己的类库插件
简单的介绍了下函数,对于理解函数这些内容远远不够,例如构造函数模式,原形模式,原形链等等都是要花很多时间去理解。
创建类
var Class = function () { var extclass = function () { //接收属性传过来的参数 this.init.apply(this, arguments); } //给类添加自定义属性 extclass.prototype.init = function () { }; //给prototypr定义别名? extclass.fn = extclass.prototype; //定义类的别名? extclass.fn.parent = extclass; //给类添加属性 extclass.extend = function (obj) { var extended = obj.extended; for (var i in obj) { extclass.fn[i] = obj[i]; } if (extended) extended(extclass); }; //给实例添加属性 extclass.include = function (obj) { var included = obj.included; for (var i in obj) { extclass.fn[i] = obj[i]; } if (included) included(extclass); } return extclass; }
类库大致的框架构建完成,这样我们创建类可以调用extended方法,创建实例可以调用include方法。下一章节会在此基础上扩展更多功能,基于原型给“类”添加继承。
相关文章推荐
- ECMAScript 创建自己的js类库
- 深入理解js立即执行函数
- 一步一步使用Ext JS MVC与Asp.Net MVC 3开发简单的CMS后台管理系统之创建项目
- 直观理解js自执行函数
- js 取一个对象的长度,取出来的是undefined,自己写的一个计算长度的函数解决了。
- js创建一个构造函数的函数
- [乐意黎原创]JS 相关函数理解
- js中(function(){…})()立即执行函数写法理解
- 关于js中函数参数“按值传递”的理解
- 一步一步学区块链(4)创建自己的私链
- ECMASCRIPT——Js中的数据类型、运算符、流程控制、函数作用域链、预解析、匿名函数自执行、怪异的几个地方
- JS的从理解对象到创建对象
- Silverlight.js中临时函数创建
- 索引 视图 存储过程和函数 简单理解 以及使用创建方法
- 变量声明和函数的提升(结合实例自己的理解)
- 一组JS创建和操作表格的函数集合
- 在立即执行函数内组合使用构造函数模式和原型模式创建对象,实现模块化开发(以daterangepicker.js为例)
- 一步一步教你在 Android 里创建自己的账号系统(一)
- 创建自己的MVC框架,深入理解mvc