源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 47|回复: 17

[JavaScript] javascript中定义私有方法说明(private method)

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2014-1-27 10:30:06 | 显示全部楼层 |阅读模式
本篇文章主要是对javascript中定义私有方法(private method)进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助

一度以为在javascript的世界里,所有方法都是公有的,无法真正从技术上定义一个私有方法,今天又一次发现:其实我错了!
复制代码 代码如下:
var Person = function(name,sex){
    this.name = name;
    this.sex = sex;     
    var _privateVariable = "";//私有变量    
    //构造器中定义的方法,即为私有方法
    function privateMethod(){   
        _privateVariable = "private value";
        alert("私有方法被调用!私有成员值:" + _privateVariable);             
    }
    privateMethod(); //构造器内部可以调用私有方法            
}

Person.prototype.sayHello = function(){
    alert("姓名:" + this.name + ",性别:" + this.sex);
}

var p = new Person("菩提树下的杨过","男");      
p.sayHello();

//p.privateMethod();//这里将报错,私成方法无法被实例调用
alert(p._privateVariable);//显示: undefined

说明:类的构造函数里定义的function,即为私有方法;而在构造函数里用var声明的变量,也相当于是私有变量。(不过类比于c#这类强类型语言中的私有成员概念还是有区别的,比如无法在非构造函数以外的其它方法中调用)

类似的,我们还能实现类似set,get属性的封装
复制代码 代码如下:
var Person = function(){    
    var salary = 0.0;

    this.setSalary = function(value){
        salary = value;
    }

    this.getSalary = function(){
        return salary;
    }
}

var p = new Person();

p.setSalary(1000);
alert(p.getSalary());//返回1000
alert(p.salary);//返回undefined

注:js中的"变量作用域","函数调用上下文(this)","闭包","原型链"这几个概念确实值得花点工夫理解,这几道坎跨过去了,js新手(比如我辈之流)的水平相信也将小上一个新台阶.

回复

使用道具 举报

2

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
25055
发表于 2022-8-18 02:12:03 | 显示全部楼层
hi哦和烦恼农家女
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
24494
发表于 2022-9-13 19:50:59 | 显示全部楼层
人都不在了啊 啊
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
25002
发表于 2022-12-6 13:17:53 | 显示全部楼层
人都不在了啊 啊
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
25487
发表于 2022-12-23 12:15:33 | 显示全部楼层
老衲笑纳了
回复 支持 反对

使用道具 举报

4

主题

1万

回帖

1万

积分

论坛元老

Rank: 8Rank: 8

积分
18852
发表于 2023-4-17 20:14:26 | 显示全部楼层
看到这帖子真是高兴!
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
24494
发表于 2023-8-31 15:54:06 | 显示全部楼层
呵呵呵呵呵呵呵a
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
24869
发表于 2023-9-3 11:20:56 | 显示全部楼层
数据库了多久撒快乐的健身卡啦
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
20466
发表于 2023-9-9 21:24:41 | 显示全部楼层
好人好人好人好人
回复 支持 反对

使用道具 举报

27

主题

2万

回帖

2万

积分

论坛元老

Rank: 8Rank: 8

积分
25961
发表于 2023-12-4 11:05:03 | 显示全部楼层
这个源码不错啊
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2025-2-11 16:37 , Processed in 0.158760 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表