博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js的实例方法和静态方法分析
阅读量:4964 次
发布时间:2019-06-12

本文共 860 字,大约阅读时间需要 2 分钟。

var Person=function(){};Person.say=function(){ console.log('I am a Person,I can say.') }; Person.prototype.getName=function(name){ console.log('My name is '+name); }

以上的代码,实际上很简单,首先是定义了一个function,js里面像上面那样定义一个function实际上是定义了一个类,接下来,我给你这个类添加了一个say的方法,然后接着给这个类的prototype添加了一个getName的方法,所有的类都是会有一个prototype这样的属性,这个属性指向的是object,这个是属于js原型链的问题,在这里我就不阐述了。好了,我现在来按照以下调用一下:

Person.say();Person.getName('Carl');

是不是发现,第一个可以正常运行,第二个会报错,再来看看下面的代码:

var carl=new Person;carl.say();carl.getName('Carl');

是不是和第一段代码刚好相反,那么这个地方实际上我们就看出来了,say方法是’.’在类上面的,所以,它实际上是一个静态方法,那么当然是可以直接通过类进行访问的(这里的静态方法都是public的),所以第一段的第一句话是不会抱错的,而getName这个方法实际上是在prototype上面的,只有创建一个实例的情况下,才可以通过实例进行访问。 

所以综上所述,定义在直接用类名(这里就是方法名)’.’一个方法,那么这个实际上创建的是一个静态方法;而用prototype’.’的一个方法,实际上创建的是一个实例方法,实例方法是需要创建实例对象进行访问的,所以,以上就是我想说的,js里面的静态方法和实例方法,同样,静态属性和实例属性也是这个道理。

转载于:https://www.cnblogs.com/faithZZZ/p/7045323.html

你可能感兴趣的文章
[Angular2 Router] Use Params from Angular 2 Routes Inside of Components
查看>>
makefile
查看>>
Spring 构造注入和Set注入复习
查看>>
python --第三方登录--微博
查看>>
Markdown基本介绍
查看>>
git,怎么说呢?应该就是看不懂意思吧?
查看>>
spring boot + vue + element-ui全栈开发入门——windows开发环境
查看>>
1. HTML 多媒体
查看>>
批量导入数据到mssql数据库的
查看>>
mysql数据库---编码格式基本操作
查看>>
《WePayUI组件设计的秘密》——2016年第一届前端体验大会分享
查看>>
BZOJ1129 : [POI2008]Per
查看>>
flutter环境配置
查看>>
NSArry 存储本地;&&读取本地文件
查看>>
实验一 通读教材《构建之法》后的问题
查看>>
Java基础:(三)运算
查看>>
Node.js+Web TWAIN,实现Web文档扫描和图像上传
查看>>
div中p标签自动换行
查看>>
<mvc:annotation-driven/>的作用
查看>>
服务器一:分布式服务器结构
查看>>