非私有属性

function Student(name, gender, age, grade, teacher){

this.name = name;

this.gender = gender;

this.age = age;

this.grade = grade;

this.teacher = teacher;

}

var bob = new Student("bob", "male", 15, 10, "Marlow");

alert(bob.age); //输出15

var susan = new Student("susan", "female", 10, 5, "Gresham");

alert(susan.gender); //输出 'female'

var bob = new Student("bob", "male", 15, 10, "Marlow");

alert(bob.age); //输出15     bob.age = 9;

alert(bob.age); //输出9;

#####################################################################################################################################

私有属性

function Student(name, gender, age, grade, teacher)     {

var studentName = name;

var studentGender = gender;

var studentGrade = grade;

var studentTeacher = teacher;

var studentAge = age;

this.getAge = function() {

return studentAge;

};

this.setAge = function(val){

studentAge = Math.abs(val); //使用绝对值,确保年龄是正值

};

}

var bob = new Student("bob", "male", 15, 10, "Marlow");

alert(bob.studentAge); //未定义,因为年龄在类定义中受私有保护

alert(bob.getAge()); //输出15     bob.setAge(-20);     alert(bob.getAge()); //输出20

#####################################################################################################################################

动态创建的访问器方法

function Student( properties ){

var $this = this;  //将类范围存储到名为$this的变量中

//迭代处理对象的属性

for ( var i in properties ) {

(function(i) {

// 动态创建访问器方法

$this[ "get" + i ] = function(){

return properties[i];

};

})(i);

}

}

// 创建一个新的用户对象实例,并传递属性的对象

var student = new Student({Name: "Bob",Age: 15,Gender: "male"});

alert(student.name); //因属性是私有的而未定义

alert(student.getName()); //输出 "Bob"

alert(student.getAge()); //输出15

alert(student.getGender()); //输出 "male"

#####################################################################################################################################

类的继承

function Worker() {

this.getMethods = function(properties, scope)

{         var $this = scope;  //将类范围存储到名为$this的变量中

//迭代处理对象的属性

for ( var i in properties ){

(function(i){                 // 动态创建访问器方法

$this[ "get" + i ] = function()

{

return properties[i];

};             //动态地创建一个分析整数,并确保是正值的更改器方法。

$this[ "set" + i ] = function(val) {

if(isNaN(val)) {

properties[i] = val;

}else{

properties[i] = Math.abs(val);

}

};

})(i);

}

};

}

// CommissionWorker "子类"和WageWorker "子类"

//继承Worker的属性和方法。

CommissionWorker.prototype = new Worker();

WageWorker.prototype = new Worker();

function CommissionWorker(properties) {

this.getMethods(properties, this);

//计算收入

this.getIncome = function(){

return properties.Sales * properties.Commission;

}

}

//要求有下列属性:薪水、每周小时数、每年周数

function WageWorker(properties) {

this.getMethods(properties, this);

//计算收入

this.getIncome = function() {

return properties.Wage * properties.HoursPerWeek * properties.WeeksPerYear;

}

}

var worker = new WageWorker(Name: "Bob", Wage: 10, HoursPerWeek: 40,WeeksPerYear: 48 });

alert(worker.wage); //未定义。薪水是私有属性。

worker.setWage(20); alert(worker.getName());   //输出 "Bob"

alert(worker.getIncome()); //输出 38,400 (20*40*48)

var worker2 = new CommissionWorker( {     Name: "Sue",     Commission: .2,     Sales: 40000 });

alert(worker2.getName());   //输出 "Sue"

alert(worker2.getIncome()); //输出8000(2% 乘40,000)

javascript面向对象实例的更多相关文章

  1. JavaScript面向对象 实例与原型

    JavaScript 面向对象 和 C# 不太一样,js 的对象是继承自原型的如下: 首先创建一个 js 实例 new  function function f () {} 这个函数 会继承 Func ...

  2. javaScript 面向对象开发实例

    javaScript 面向对象开发实例 这个是结合require的模块化开发,首先创建构造函数: //test.js 1 function Test(lists) { var config={ nam ...

  3. JavaScript学习总结(三)——this、原型、javascript面向对象

    一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...

  4. javascript面向对象系列第四篇——选项卡的实现

    前面的话 面向对象的应用并非只是读几本书那么容易,需要有大量的工程实践做基础才能真正理解并学会使用它.本文将用面向对象的技术来制作一个简单的选项卡 图示说明 由图示结果看到,这是一个非常简单的选项卡. ...

  5. javascript面向对象系列第三篇——实现继承的3种形式

    × 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...

  6. javascript面向对象系列第一篇——构造函数和原型对象

    × 目录 [1]构造函数 [2]原型对象 [3]总结 前面的话 一般地,javascript使用构造函数和原型对象来进行面向对象编程,它们的表现与其他面向对象编程语言中的类相似又不同.本文将详细介绍如 ...

  7. Javascript面向对象(封装、继承)

    Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...

  8. 【转】javascript面向对象编程

    摘要:本文本来是想自己写的,奈何花了好长时间写好之后忘记保存,还按了刷新键,一键回到解放前,索性不写了,所以本文是转载的. 面向对象编程是用抽象方式创建基于现实世界模型的一种编程模式,主要包括模块化. ...

  9. javascript面向对象(一):封装

    本文来自阮一峰 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握. 下面就是我的学 ...

随机推荐

  1. CentOS下判断自己的VPS是OpenVZ的还是Xen的

    一般来说,VPS的虚拟化技术,有Xen.OpenVZ.Xen HVM和VMware这几种,那么,如何判断自己的VPS是基于哪种虚拟化技术的呢? 1.执行:ls /proc/命令,一般Xen的VPS,/ ...

  2. RHEL7服务管理

    对于学习过红帽RHEL6的系统或已经习惯使用service.chkconfig等命令来管理系统服务的用户可能要郁闷了, 因为在红帽RHEL7系统中管理服务的命令变成了“systemctl”,但使用方法 ...

  3. BeautifulSoup 安装使用

    Linux环境 1. 安装 方法一: 下载:http://www.crummy.com/software/BeautifulSoup/bs4/download/4.2/ 解压:tar -xzvf be ...

  4. uploadify+批量上传文件+java

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  5. 关于JavaScript的思考

    像apply这种函数,只有动态语言才能完成,动态语言既编译器/解释器这类代码生成器完成自己职责时只能在运行时完成,例如函数参数的压栈.仔细想想可能不对,也可以通过编译来完成 apply和call的使用 ...

  6. php面向对象的三大特征 封装,继承,多态

    对象的主要三个特性 对象的行为:可以对 对象施加那些操作,开灯,关灯就是行为. 对象的形态:当施加那些方法是对象如何响应,颜色,尺寸,外型. 对象的表示:对象的表示就相当于身份证,具体区分在相同的行为 ...

  7. Android 如何设置默认语言

    前言          欢迎大家我分享和推荐好用的代码段~~ 声明          欢迎转载,但请保留文章原始出处:          CSDN:http://www.csdn.net        ...

  8. Linux之Samba的配置

    Samba的配置   对于linux与windows共享,和平共处,我们可以用Samba软件 Samba是一套免费的开源软件,可以在linux或其他类unix操作系统上实现windows域控制器,文件 ...

  9. 深入理解Java内存模型(四)——volatile

    volatile的特性 当我们声明共享变量为volatile后,对这个变量的读/写将会很特别.理解volatile特性的一个好方法是:把对volatile变量的单个读/写,看成是使用同一个监视器锁对这 ...

  10. 最全的PHP常用函数大全

    PHP的一些常用函数 quotemeta() 函数在字符串中某些预定义的字符前添加反斜杠. quoted_printable_decode() 函数对经过 quoted-printable 编码后的字 ...