这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
下面小编就为大家带来一篇老生常谈 Javascript 中的原型和 this 指针。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,祝大家游戏愉快哦
1、Javascript 中的原型:
原型 prototype 是 Javascript 中特有的一个概念。通过原型,Javascript 可以实现继承机制。
Javascript 本身是基于原型的,每一个对象都有一个 prototype 属性。而 Object 对象的 prototype 属性为 null。
下面来看一个使用原型实现继承的例子:
1.1 使用原型实现继承:
- function Person(name) {
- this.name = name;
- this.getName = function() {
- return this.name;
- }
- }
- function Artist(type) {
- this.type = type;
- this.getType = function() {
- return this.type;
- }
- }
- Artist.prototype = new Person("arthinking");
- var artist = new Artist("Guitar");
- alert(artist.getType()); //本身就有type属性
- alert(artist.getName()); //从Person原型链上继承到的属性和方法
2、this 指针:
Javascript 中的 this 指针与传统的面向对象中的有些不同。传统的面向对象中 this 指针在类中声明的,表示对象本身。
Javascript 中 this 表示当前上下文,即调用者的引用。Javascript 中 this 代表的对象不是根据函数的声明而确定的,而是根据的调用而确定的。下面展示了一个函数中的 this 使用 call 指定具体代表的对象:
- var test1 = {
- name : "test1"
- }
- var test2 = {
- name : "test2"
- }
- function getName(){
- return this.name; //this根据传调用该函数的上下文来确定的,定义该函数时,this指针并不确定
- }
- alert(getName.call(test1));
这里的 call 是 Function 的一个函数。
来源: http://www.phperz.com/article/17/0519/331344.html