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模型很独特,和其他语言都不一样,初学者不容易掌握. 下面就是我的学 ...
随机推荐
- 270. Closest Binary Search Tree Value
题目: Given a non-empty binary search tree and a target value, find the value in the BST that is close ...
- Excel有用的宏
=Index({"同事","同学","亲戚"},b3) 前面的array默认索引从1开始. 如果b3为1.而枚举数组是: 0=>同事, ...
- Android NDK 和 OpenCV 整合开发总结(3)
Android NDK 和 OpenCV 整合开发总结(3) http://hujiaweibujidao.github.io/blog/2013/11/18/android-ndk-and-open ...
- Maven+Spring+MVC结构中,jetty/tomcat是如何启动项目的[转]
针对maven配置的Spring+MVC项目,我们用Maven自带的jetty和tomcat插件进行调试,这很方便.但是调试时,这些插件所启动的web服务器,是如何来将我们的工程作为一个web项目启动 ...
- [原]poj2243-Knight Moves-水bfs
#include<iostream> #include<cstdio> #include<cstring> #include<queue> using ...
- ViewState压缩技术
ViewState 的使用,大家可以说是又爱又恨,它其中一个特性就是保存页面的状态,对于只是展示的页面,我们可以直接在页面文件中使用 EnableViewState="false" ...
- 深入理解Java对象的序列化与反序列化的应用
当两个进程在进行远程通信时,彼此可以发送各种类型的数据.无论是何种类型的数据,都会以二进制序列的形式在网络上传送.发送方需要把这个Java对象转换为字节序列,才能在网络上传送:接收方则需要把字节序列再 ...
- eclipse有生成不带参数的构造方法的快捷键吗
你打上类名的2个字母,然后”alt“ +“/” 基本上选第一个就行了
- .NET 实现异步处理的集中方式
对于异步,相信大家都不十分陌生.准确点来说就是方法执行后立即返回,待到执行完毕会进行通知.就是当一个任务在执行的时候,尤其是需要耗费很长的时间进行处理的任务,如果利用单线程进行操作的话,势必造成界面的 ...
- uses-permission权限汇总
问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES ,读取或写入登记check-in数据库属性表的权限 获取错略位置 android.permis ...