欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【ECMAScript 创建自己的js类库】,下面是详细的讲解!
ECMAScript 创建自己的js类库
ECMAScript中最有意思,最强大的地方在于函数。最进在完善自己的js类库的时候发现我们经常在用函数,但真的很少有人懂得ECMAScript函数功能。
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类库的用户互动如下:
相关问题:ECMAScript js 关系?
答:1997年06月ECMA-262的第一个版本被欧洲计算机制造商协会采纳。并将 ECMA-262 标准取名为 ECMAScript。 所以ECMAScript实际上是一种脚本在语法和语义上的标准。 JavaScript是ECMA-262标准的实现和扩展。即基于ECMAScript。类似的还有JScript和Act... >>详细
相关问题:我在建网站的时候,技术跟我说js,js是什么意思?
答:JS是客户端脚本语言,是前端技术。 可以做特效,也可以和后台互动,总之是网站不可缺的一部分。 具体你百度搜索JS,有详细解释的。 >>详细
相关问题:javascript哪些对象不能被new而哪些可以·麻烦说的...
答:js可以创建并使用的对象有三种:本地对象、内置对象和宿主对象。本地对象就是 ...所有非本地对象都是宿主对象(host object),即由 ECMAScript 实现的宿主环境提供... >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【ComboBox】ComboBox 和 DateField 在IE下消失的
- 【dom】javascript dom追加内容实现示例-追加内容
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【Array】js中更短的 Array 类型转换-类型转换
- 【append】append和appendTo的区别以及appendChil
- 【ExtJs】ExtJs 表单提交登陆实现代码-表单提交-
- 【ajax清除浏览器缓存】Ajax清除浏览器js、css、
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
