js中公有方法、特权方法、静态方法
1.公有属性和公有方法
|
1
2
3
4
5
6
7
8
9
|
function User(name,age){ this.name = name;//公有属性 this.age = age;}User.prototype.getName = function(){//公有方法 return this.name;}var user = new User('fire子海',26);console.log(user.getName());//output:fire子海 |
2.私有属性和方法
|
1
2
3
4
5
6
7
8
9
|
function User(name,age){ var name = name;//私有属性 var age = age; function alertAge(){//私有方法 alert(age); } alertAge(age); //弹出26}var user = new User('fire子海',26); |
3.静态属性和方法
在php中,无需实例化就可以调用的方法就叫静态方法,js也一样,无需实例化,即用new操作符实化对象,就可调用对象的方法和属性。
|
1
2
3
4
5
6
7
8
|
function User(){}User.age = 26;//静态属性User.myname = 'fire子海';User.getName =function(){//静态方法 return this.myname;//如果这里使用this.name,返回的将是User,所有改用了myname,}console.log(User.getName());//output:fire子海 |
4.特权方法
|
1
2
3
4
5
6
7
8
9
|
function User(name,age){ var name = name;//私有属性 var age = age; this.getName = function(){ //特权方法 return name;//私有属性和方法不能使用this调用 }}var user = new User('fire子海',26);console.log(user.getName());//output:fire子海 |
5.静态类
对于静态方法和静态属性,我们无需像第三步中那样去创建,如果网友看过我那篇“js如何制作图片轮播”,就知道可以使用字面量的方式来创建。
|
1
2
3
4
5
6
7
8
9
10
11
|
var user = { init:function(name,age){ this.name = name; this.age = age; }, getName:function(){ return this.name; }}user.init('fire子海',26);console.log(user.getName());//output:fire子海 |
6.公有方法的调用规则
调用公有方法,我们必需先实例化对象
公有方法中通过不this调用公有属性和特权方法,不能使用this调用静态方法和属性,必需裁通过对象本身调用,即对象名。公有方法也不能调用私有方法
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
function User(){ this.myname = 'fire子海';//公有属性 this.age = 26; this.do = function(){//特权方法 return this.myname+'学习js'; }}User.eat = function(food){ return '晚餐只有'+food;}User.prototype.alertAge = function(){ alert(this.age);}User.prototype.alertDo = function(){ alert(this.do());//调用特权方法}User.prototype.alertEat = function(food){ alert(User.eat(food));//只能通过对象本身调用静态方法 //alert(this.ear(food))这样调用将出错:this.eat is not a function}var user = new User();user.alertAge();//alert:26user.alertDo();//alert:fire子海学习jsuser.alertEat('方便面')//alert:晚餐只有方便面 |
7.静态方法的调用规则
使用静态方法时,无需实例化对象,便可以调用,对象实例不能调用对象的静态方法,只能调用实例自身的静态属性和方法
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
function User(){}User.age = 26;//静态属性User.myname = 'fire子海';User.getName =function(){//静态方法 return this.myname;}var user = new User();console.log(user.getName);//TypeError: user.getName is not a functionuser.supper = '方便面';user.eat = function(){ return '晚餐只有'+this.supper;}user.eat();//晚餐只有方便面 |
静态方法无法调用公有属性、公有方法、私有方法、私有属性、特权方法和原型属性
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
function User(){ this.myname = 'fire子海';//公有属性 this.age = 26; this.do = function(){//特权方法 return this.myname+'学习js'; }}User.prototype.alertAge = function(){//公共方法,也叫原型方法 alert(this.age);}User.prototype.sex = '男';//原型属性User.getName= function(){//静态方法 return this.myname;}User.getAge = function(){ this.alertAge(); }User.getDo = function(){ return this.do();}//console.log(User.getName())//undefined//console.log(User.getDo());//TypeError: this.do is not a function//console.log(User.getAge())//TypeError: this.alertAge is not a function |
8.特权方法的调用规则
特权方法通过this调用公有方法、公有属性,通过对象本身调用静态方法和属性,在方法体内直接调用私有属性和私有方法
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
function User(girlfriend){ var girlfriend = girlfriend; function getGirlFriend(){ return '我女朋友'+girlfriend+'是美女!'; } this.myname = 'fire子海';//公有属性 this.age = 26; this.do = function(){//特权方法 return this.myname+'学习js'; } this.alertAge = function(){ this.changeAge();//特权方法调用公有方法 alert(this.age); } this.alertGirlFriend = function(){ alert(getGirlFriend());//调用私有方法 }}User.prototype.changeAge = function(){ this.age = 29;}var user = new User('某某');user.alertAge();//alert:29user.alertGirlFriend();//alert:我的女朋友某某是美女! |
9.私有方法
对象的私有方法和属性,外部是不可以访问的,在方法的内部不是能this调用对象的公有方法、公有属性、特权方法的
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
function User(girlfriend){ var girlfriend = girlfriend; this.myname = 'fire子海';//公有属性 this.age = 26; function getGirlFriend(){ //this.myname ;//此时的this指向的window对象,并非User对象, // this.myname = 'fire子海',此时的this指向的是getGirFriend对象了。 //如果通过this调用了getGirFriend中不存在的方法呀属性,this便会指向window 对象,只有this调用了getGirlFriend存在的方法和属性,this才会指定getGirlFriend; alert(User.eat('泡面'));//alert:晚餐只有方便面 } this.do = function(){//特权方法 return this.myname+'学习js'; } this.alertAge = function(){ this.changeAge();//特权方法调用公有方法 alert(this.age); } this.alertGirlFriend = function(){ getGirlFriend();//调用私有方法 }}User.eat = function(supper){ return '晚餐只有'+supper;}var user = new User('某某');user.alertGirlFriend(); |
js中公有方法、特权方法、静态方法的更多相关文章
- node.js中的url.parse方法使用说明
node.js中的url.parse方法使用说明:https://blog.csdn.net/swimming_in_it_/article/details/77439975 版权声明:本文为博主原创 ...
- JavaScript【面向对象】-静态方法-私有方法-公有方法-特权方法
JavaScript面向对象是近年来比较火的一个概念了,由于小弟才疏学浅,虽然做过不少的web项目,看了网上很多深奥的资料和教程,还是对他们深奥 的理论一知半解,前段时间看了点书,总算有了自己的理解, ...
- JS中 call() 与apply 方法
1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一个对象替换当前对象. 说明: call ...
- JS中定义类的方法
JS中定义类的方式有很多种: 1.工厂方式 function Car(){ var ocar = new Object; ocar.color = "blue" ...
- js中this和回调方法循环-我们到底能走多远系列(35)
我们到底能走多远系列(35) 扯淡: 13年最后一个月了,你们在13年初的计划实现了吗?还来得及吗? 请加油~ 主题: 最近一直在写js,遇到了几个问题,可能初入门的时候都会遇到吧,总结下. 例子: ...
- js中object的申明方法
//js中的对象申明使用new Object(); //object类型的数据类似于数组通过下表来访问其中的值 //example1 var person=new Object(); person.n ...
- JS中令人发指的valueOf方法介绍
彭老湿近期月报里提到了valueOf方法,兴致来了翻了下ECMA5里关于valueOf方法的介绍,如下: 15.2.4.4 Object.prototype.valueOf ( ) When the ...
- js 中读取JSON的方法探讨
方法一:函数构造定义法返回 var strJSON = "{name:'json name'}"; //得到的JSONvar obj = new Function("r ...
- JS中定义类的方法<转>
转载地址:http://blog.csdn.net/sdlfx/article/details/1842218 PS(个人理解): 1) 类通过prototype定义的成员(方法或属性),是每个类对象 ...
随机推荐
- 004-C3P0连接池工具类模板
package ${enclosing_package}; import java.sql.Connection; import java.sql.ResultSet; import java.sql ...
- 使用SubstanceDesign和Unity插件ShaderForge制作风格化火焰
使用 SubstanceDesign 软件可以制作shader用的特殊图片,原来真有这种软件,一直好奇这种图片怎么做的 https://www.kancloud.cn/hazukiaoi/sd_sf_ ...
- unity 读取外部exe程序控制台信息
由于需要获取显卡信息,但是unity的自带函数,只能输出1个显卡 c#倒是可以但是引用了一个下载的dll System.Management.dll 这个dll放到unity用不了,因为mono不 ...
- Array【数组】和Object【对象】的特性比较
数组是JavaScript提供的一个内部对象,它是一个标准的集合,我们可以添加(push).删除(shift)里面元素,我们还可以通过for循环遍历里面的元素. 那么除了数组我们在JavaScript ...
- linux多线程同步
1. 互斥量是线程同步的一种机制,用来保护多线程的共享资源.同一时刻,只允许一个线程对临界区进行访问.互斥量的工作流程:创建一个互斥量,把这个互斥量的加锁调用放在临界区的开始位置,解锁调用放到临界区的 ...
- Mybatis的关联查询(一)
一对一的关联查询 一.使用resultType进行输出映射 1. 创建一个新的PO类,由于要将查询出来的属性映射到新的PO类.所有该PO类中应该有查询出来的所有列对应的属性. //定义新的PO类, ...
- Bash编程(6) String操作
1. 拼接 1) 简单的字符串拼接如:PATH=$PATH:$HOME/bin.如果拼接的字符串包含空格或特殊字符,需要使用双引号括起,如: var=$HOME/bin # 注释并不是赋值的一部分 v ...
- centos6.x硬件信息统计脚本
#!/bin/bash Line='===========' #linux发行版名称 if [[ -f /usr/bin/lsb_release ]]; then OS=$(/usr/bin/lsb_ ...
- Splunk和ELK深度对比
转自:http://blog.51cto.com/splunkchina/1948105 日志处理两大生态Splunk和ELK深度对比 heijunmasd 0人评论 5312人阅读 2017-07- ...
- WPF TextBox 聚焦
1.利用行为 http://blog.csdn.net/lianchangshuai/article/details/9223125 2. 利用装饰器 http://stackoverflow.com ...