关于Javascript定义函数和this使用的两点注意的地方
来源:互联网 发布:linux硬件级虚拟机 编辑:程序博客网 时间:2024/05/01 22:32
总结:
一、函数定义:
1.在实例和类上都可以直接定义函数
2.不能在实例上使用prototype定义函数,只能在类上使用prototype定义函数
3.类上直接定义的函数不能使用this访问对象的属性
4.在类的prototype上建立的函数可以用this,在类内部定义的函数可以使用this,在对象实例上建立的函数额可以this
- window.alert=function (msg)
- {
- document.write(msg+"<br>");
- }
- function say()
- {
- this.f="props";
- this.func3=function(){alert("f3,"+this.f);}
- }
- say.func1=function(){alert("func1,"+this.f);}; //Error,类上直接定义的函数,不能使用this
- say.prototype.func2=function(){alert("func2,"+this.f);}
- say.func1();
- (new say()).func2();
- say.func2(); //Error, 在用prototype定义的函数,必须实例化对象才能调用
- say.func3(); //Error,在类上定义的函数,必须实例化才能调用
- (new say()).func3();
- var obj={
- fld1:10,
- func1:function(msg){alert(msg);},
- func4:function(){alert(this.fld1);}
- }
- obj.prototype.func=function(){alert("func");}; //Error 实例对象上不能使用prototype定义对象
- obj.func2=function(){alert("func2,"+this.fld1);}; //ok,实例上直接定义的函数可以使用this,访问对象的属性
- alert(obj.fld1);
- obj.func1("func1");
- obj.func2();
- obj.func4();
- 关于Javascript定义函数和this使用的两点注意的地方
- 关于构造函数继承的两点注意
- 使用execvp()函数需要注意的两点
- 使用execvp()函数需要注意的两点
- 关于#define宏定义值得注意的两点
- Javascript定义函数和this使用
- 关于rand()函数需要注意的地方
- 关于inet_ntoa使用需要注意的地方
- 关于block使用需要注意的地方
- 关于使用listView应该注意的地方
- Java常量定义需要注意的两点
- 注意javascript的this
- 通过JavaScript定义函数的注意点
- JavaScript需要注意的地方
- 关于函数的定义和使用
- 关于javascript的两点注意事项
- 关于JavaScript对象的两点
- 关于在Linux下使用select函数需要注意的地方
- 关于prototype.js的一些技术说明 bind bindAsEventLinstener
- 数组实现大数相乘
- 黑屏后面藏了什么?--解读微软打击盗版
- 戴尔手握100亿美元现金扬言将展开收购
- 大中型网站架构探秘
- 关于Javascript定义函数和this使用的两点注意的地方
- Javascript对url进行编码的几个函数
- 2008.10.23 C基础
- 学习很累
- Prototype使用学习手册指南之Selector.js
- Prototype使用学习手册指南之dom.js
- Prototype使用学习手册指南之ajax.js
- 图的邻接矩阵实现
- 判断JavaScript对象是否可用的正确方法