javascript 原型方法,对象方法,类方法;私有属性,公有属性,公有静态属性

本文介绍了JavaScript中对象方法、类方法及原型方法的概念与应用。重点讲解了如何利用原型方法实现实例间的资源共享,减少内存占用。同时对比了不同方法定义方式的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.概要

1、对象方法理解就很简单了,主要是如果类生成一个实例,那么该实例就能使用该方法

2、类方法,不需要通过生成实例就可以使用的方法

3、原型方法主要是用来对JS已有的系统对象进行扩展而生的,例如Array数组没有什么方法,你可以为其增加原型方法,那么创建的数组就拥有了该方法。

1、对象方法包括构造函数中的方法以及构造函数原型上面的方法;

2、类方法,其实这里的类就是一个函数,在js中由于函数也是一个对象,所以可以为函数添加属性以及方法,这种方法在node中用的比较多;

3、原型方法一般用于对象实例共享,比如Person.prototype.sayName=function(){console.log(this.name);};在原型上面添加该方法,就能实现共享。这样就不用每一次初始化一个实例的时候,为其分配相应的内存了。虽然原型方法可以实现实例共享原型方法,节省内存堆空间,但是并非只有prototype方式才能达到这种效果我们可以将方法以函数的形式定义在构造函数之外,然后在构造函数中通过this.method = method的方式,这样生成的实例的方法也都通过索引指向一个函数,具体如下:

不使用原型定义方法:

(function() {

 function Constractor() {

 this.method1 = method1;

 this.method2 = method2;

 }

 function method1() { }

  function method2() {}

})();

一般使用原型定义时代码如下:

(function () {

 function Constractor() { }

 Constactor.prototype = {

 method1: function() { },

 method2: function() { } 

};

 // 或者 

Constactor.prototype.method1 = function() { };

       Constactor.prototype.method2 = function() { };

})();


理论和实现都没有什么高深的,只是为了达到同样的目的,可以通过不同的途径,只是此种方式在使用instanceOf运算符来判断继承关系时就不奏效了。


2.主题

<html>
	<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
		<title>test</title>
	</head>
	<body>
		<script>
		//对象构造函数
		function Atest(name){
			//私有属性,只能在对象构造函数内部使用
			var className = "Atest";
			//公有属性,在对象实例化后调用
			this.name = name;
			//对象方法
			this.hello = function(){
				alert(this.name);
				alert(this.msg());//使用原型方法扩充的方法可以在类内部使用
				alert(this.sex);//使用原型方法扩充的属性可以在类内部使用
				alert(Atest.age);//静态属性调用时格式为[对象.静态属性]
			}
		}
		//类方法 (实际是静态方法直接调用) 位置:Person类的外部 语法格式:类名称.方法名称 = function([参数...]){ 语句行; }
		Atest.Run = function(){
			alert("我是类方法 Run");
		}


		//原型方法
		Atest.prototype.msg = function(){
			alert("我的名字是:"+this.name);//如果原型方法当作静态方法直接调用时,this.name无法被调用
		}

		//公有静态属性 在类的外部
		Atest.age = 20;//公有静态属性不能使用 【this.属性】,只能使用 【对象.属性】 调用

		//原型属性,当作是类内部的属性使用【this.原型属性】,也可以当成公有静态属性使用【对象.prototype.原型属性】
		Atest.prototype.sex = "男";

		Atest.Run(); //类方法也是静态方法,可以直接使用 【对象.静态方法()】
		Atest.prototype.msg();//原型方法当成静态方法使用时【对象.prototype.方法()】 
		alert(Atest.prototype.sex);//原型属性当作静态属性使用时【对象.prototype.方法()】
		var a = new Atest("zhangsan");//对象方法和原型方法需要实例化对象后才可以使用
		a.hello();//对象方法必须实例化对象
		a.msg();//原型方法必须实例化对象
		alert(a.age)://错误,公有静态属性只能使用 【对象.属性】调用

		//ps:尽量将方法定义为原型方法,原型方法避免了每次调用构造函数时对属性或方法的构造,节省空间,创建对象快.
	</script>
	</body>
</html>



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值