javascript面向对象实例
非私有属性
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面向对象实例的更多相关文章
- JavaScript面向对象 实例与原型
JavaScript 面向对象 和 C# 不太一样,js 的对象是继承自原型的如下: 首先创建一个 js 实例 new function function f () {} 这个函数 会继承 Func ...
- javaScript 面向对象开发实例
javaScript 面向对象开发实例 这个是结合require的模块化开发,首先创建构造函数: //test.js 1 function Test(lists) { var config={ nam ...
- JavaScript学习总结(三)——this、原型、javascript面向对象
一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...
- javascript面向对象系列第四篇——选项卡的实现
前面的话 面向对象的应用并非只是读几本书那么容易,需要有大量的工程实践做基础才能真正理解并学会使用它.本文将用面向对象的技术来制作一个简单的选项卡 图示说明 由图示结果看到,这是一个非常简单的选项卡. ...
- javascript面向对象系列第三篇——实现继承的3种形式
× 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...
- javascript面向对象系列第一篇——构造函数和原型对象
× 目录 [1]构造函数 [2]原型对象 [3]总结 前面的话 一般地,javascript使用构造函数和原型对象来进行面向对象编程,它们的表现与其他面向对象编程语言中的类相似又不同.本文将详细介绍如 ...
- Javascript面向对象(封装、继承)
Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...
- 【转】javascript面向对象编程
摘要:本文本来是想自己写的,奈何花了好长时间写好之后忘记保存,还按了刷新键,一键回到解放前,索性不写了,所以本文是转载的. 面向对象编程是用抽象方式创建基于现实世界模型的一种编程模式,主要包括模块化. ...
- javascript面向对象(一):封装
本文来自阮一峰 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握. 下面就是我的学 ...
随机推荐
- CentOS下判断自己的VPS是OpenVZ的还是Xen的
一般来说,VPS的虚拟化技术,有Xen.OpenVZ.Xen HVM和VMware这几种,那么,如何判断自己的VPS是基于哪种虚拟化技术的呢? 1.执行:ls /proc/命令,一般Xen的VPS,/ ...
- RHEL7服务管理
对于学习过红帽RHEL6的系统或已经习惯使用service.chkconfig等命令来管理系统服务的用户可能要郁闷了, 因为在红帽RHEL7系统中管理服务的命令变成了“systemctl”,但使用方法 ...
- BeautifulSoup 安装使用
Linux环境 1. 安装 方法一: 下载:http://www.crummy.com/software/BeautifulSoup/bs4/download/4.2/ 解压:tar -xzvf be ...
- uploadify+批量上传文件+java
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- 关于JavaScript的思考
像apply这种函数,只有动态语言才能完成,动态语言既编译器/解释器这类代码生成器完成自己职责时只能在运行时完成,例如函数参数的压栈.仔细想想可能不对,也可以通过编译来完成 apply和call的使用 ...
- php面向对象的三大特征 封装,继承,多态
对象的主要三个特性 对象的行为:可以对 对象施加那些操作,开灯,关灯就是行为. 对象的形态:当施加那些方法是对象如何响应,颜色,尺寸,外型. 对象的表示:对象的表示就相当于身份证,具体区分在相同的行为 ...
- Android 如何设置默认语言
前言 欢迎大家我分享和推荐好用的代码段~~ 声明 欢迎转载,但请保留文章原始出处: CSDN:http://www.csdn.net ...
- Linux之Samba的配置
Samba的配置 对于linux与windows共享,和平共处,我们可以用Samba软件 Samba是一套免费的开源软件,可以在linux或其他类unix操作系统上实现windows域控制器,文件 ...
- 深入理解Java内存模型(四)——volatile
volatile的特性 当我们声明共享变量为volatile后,对这个变量的读/写将会很特别.理解volatile特性的一个好方法是:把对volatile变量的单个读/写,看成是使用同一个监视器锁对这 ...
- 最全的PHP常用函数大全
PHP的一些常用函数 quotemeta() 函数在字符串中某些预定义的字符前添加反斜杠. quoted_printable_decode() 函数对经过 quoted-printable 编码后的字 ...