1.对象中包含什么

在javascript中,从函数到字符串实际上都是对象

  • 继承
//创建一个person对象的实例
var penson={};
person.getName=function(){...};
person.getAge=function(){...}; //创建一个emloyee对象的实例
var employee={};
employee.getTitle=function(){...};
employ.getSalary=function(){...}; //从person对象中继承方法
employee.getName=person.getName;
employee.getAge=person.getAge;
  • 理解对象成员
ADS.addEvent(window,'load', function() {
alert('document.body is a: ' + document.body);
});//document.body is a:object HTMLBodyElement ADS.addEvent(window,'load',function() {
alert('document.getElementById is a: ' + document.getElementById);
});
//document.getElementById is a:
//function getElementById(){[native code]}
  • window对象中的一切(覆盖作用域链中的对象)
<h1>Override the alert() method</h1>
<p>Interesting isn't it?</p>

function override() {
// 覆盖alert函数
var alert = function(message) {
window.alert('overridden:' + message);
};
alert('alert'); // 在override()函数的作用域中调用原始的alert()函数
window.alert('window.alert');
}
override(); // 在window的作用域中调用原始的alert();
alert('alert from outside');
//弹出顺序:
//overridden:alert
//window.alert
//alert from outside
  • 理解作用域和闭包是根本

2.创建你自己的对象

var myObject=new Object();//Object是一个对象
var myObject={};
//这两种都已经被实例化。实例化的对象一定是一个构造函数
//创建一个数组
var myArray=new Array();
var anotherObject=new myObject();//错误的
  • 一变多:创建构造函数
function myConstructor(a){
//somecode
}
var myConstructor=function(a){
//comecode
}
var myConstructor=new function('a','/*somecode*/')//性能有问题
//使用
var myObject=new myConstructor();
//再比如:
function myConstructor(message)
{
alert(message);
this.myMessage=message;
}
var myObject=new myConstructor('Instantiating myObject');
var message=myObject.myMessage;
  • 添加静态方法
//了解实例与构造函数之间的区别有助于消除许多已有的问题
//-------仅对Object能正常运行
//创建一个Object对象实例
var myObject=new Object();
//添加一个属性
myObject.name='Jeff';
//添加一个方法
myObject.alertName=function()
{
alert(this.name);
}
//执行添加的方法
myObject.alertName(); //创建一个Function对象的实例
var myConctructor=function()
{
//somecode
}
//添加一个静态属性
myConstructor.name='Jeff';
myConstructor.alertName=function()
{
alert(this.name);
}
myConstructor.alertName();
//但是,name,alertName不会在新实例中
var anotherExample=new myConstructor();
anotherExample.alertName();//not a function 错误
  • 像原型中添加静态方法
//创建构造函数
functionmyConstrctor(message)
{
alert(message);
this.myMessage=message;
}
//添加一个公共方法(在底层添加)
myConstructor.prototype.clearMessage=function(string)
{
this.myMessage+=''+string;
}
//可以在新的实例上调用该方法
var myObject=new myConstructor('Hello World!');
myObject.clearMessage();

通过私有和特权成员控制访问(只需在该构造函数中使用普通的var和fuction关键字即可)

//创建构造函数
function myConstrctor(message)
{
this.myMessage=message;
//私有属性
var separator='-';
var myOwner=this;
//私有方法
function alertMessage()
{
alert(myOwner.message);
}
//在实例化时显示信息;
alertMessage();
} //如果通过如下方法,则出错
myConstructor.prototype.appendToMessage=function(string)
{
this.myMessage+=seqarator+string;//出错 未定义
}
//特权方法只得是在构造函数中的作用域中使用this关键字定义的方法
//创建构造函数
function myConstrctor(message)
{
this.myMessage=message;
//私有属性
var separator='-';
var myOwner=this;
//私有方法
function alertMessage()
{
alert(myOwner.message);
}
//在实例化时显示信息;
alertMessage(); //特权方法
this.appendToMessage=function(string)
{
this.mymessage+=separator+string;
alertMessage();
}
}
//这时候就可以
var myObject=new myConstructor('Hello World');
myObject.appendToMessage('Jeff'); //但是仍然不能用下面方法:
myObject.alertMessage();//not found
  • 共有、私有、特权、静态成员真的那么重要么?
//创建构造函数
function myConstrctor(message)
{
this.myMessage=message;
//私有属性
var separator='-';
var myOwner=this;
//私有方法
function alertMessage()
{
alert(myOwner.message);
}
//在实例化时显示信息;
alertMessage(); //特权方法
this.appendToMessage=function(string)
{
this.mymessage+=separator+string;
alertMessage();
}
}
//共有方法
myConstructor.prototype.clearMessage=function(string)
{
this.myMessage='';
}
//静态属性
myConctructor.name='Jeff'; //静态方法
myConstructor.alertName=function()
{
alert(this.name);
}

记住一下几天规则可以保证你对所有成员的身份做出适当的界定:

  • 由于私有和特权成员在函数内部。新词他们会被带到函数的每个实例中。
  • 共有的原型成员是对象蓝图的一部分,适用于通过new关键字实例化的该对象的每个实例
  • 静态成员只使用于对象的一个特殊实例。
  • 对象字面量

JavaScript DOM高级程序设计2.1创建可重用的对象--我要坚持到底!的更多相关文章

  1. JavaScript DOM 高级程序设计读书笔记一

    创建可重用的对象 简而言之,对象就是包含一组变量(称为属性)和函数(称为方法)的集合的实例.对象通常由类派生而来,而类中定义了对象拥有的属性和方法.如果你的脚本中都是对象之间的交互操作,那么就可以称之 ...

  2. JavaScript DOM高级程序设计 7.向应用程序加入Ajax--我要坚持到底!

    有时候,或许是因为理解能力,也或许是因为浮躁,看东西总是不入心,而且还老是想跳过本节,或者赶紧看完本节,这样的恶性循环,让我在即没有真正的学习到知识,又打击我的学习信心,还浪费了我很多事件,我想,当遇 ...

  3. JavaScript DOM高级程序设计 3.6 实例 将HTML代码转换成DOM代码(附源码)--我要坚持到底!

    作为一名Web开发者,最讨厌的事情就是重复性任务,摆脱乏味的日常重复性事物的一种方法,是借助可重用的对象或者说与你现在建立的ADS库类似的库,另外一种让事情变得有意思,且能够加速开发进程的方式是编写能 ...

  4. JavaScript DOM高级程序设计1.2-循序最佳实践--我要坚持到底!

    我这人,最大的毛病就是浮躁. 下面开始我再一次的学习之旅,希望我能坚持到最后.记笔记除了分享以外,更重要的是让自己看见自己学习之路. 先把ADS库贴出来http://vdisk.weibo.com/s ...

  5. JavaScript DOM高级程序设计 4.3控制事件流和注册事件侦听器--我要坚持到底!

    一.事件流 我们通过下面一个实例,进行说明. <body> <h1>Event Flow</h1> <ul id="nav"> &l ...

  6. JavaScript DOM高级程序设计 3.-DOM2和HTML2--我要坚持到底!

    由一个HTML进行说明,我就不敲了,直接copy <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" " ...

  7. JavaScript DOM高级程序设计 5动态修改样式和层叠样式表1(源代码)--我要坚持到底!

    W3C DOM2样式规范 现在这边贴出本章要的源代码,注意要结合前面用到的ADS库http://vdisk.weibo.com/s/Dq8NU CSSStyleSheet对象属性: type :始终是 ...

  8. JavaScript DOM高级程序设计 2.4-try{}catch{}--我要坚持到底!

    先看一段有异常的语句 var sound = 'Roar!'; function myOrneryBeast() { this.style.color='green';//window没有style属 ...

  9. JavaScript DOM 高级程序设计读书笔记二

    响应用户操作和事件 事件就是操作检测与脚本执行的组合,或者基于检测到的操作类型在某个对象上调用事件侦听器(事件处理程序). 事件的类型 事件可以分为几种类型:对象事件,鼠标事件,键盘事件(只适用于do ...

随机推荐

  1. 防止非授权用户调用DLL

    1.首先要创建一个密钥文件(*.snk)

  2. 重写session

    <?php ini_set('session.use_only_cookies', 0); $session_id = rand(10000, 99999); session_set_cooki ...

  3. python学习之js从0开始

    <html> <head> <title>js页面</title> <script src="js/old_boy.js"&g ...

  4. 求小于等于n的所有素数

    题目:要求输出所有小于等于n的素数(n>=2,且为正整数) 要求:1.每行输出10个素数 2.尽可能采用较优算法 #include<iostream> #include<cma ...

  5. The Black Hole of Numbers (strtoint+inttostr+sort)

    For any 4-digit integer except the ones with all the digits being the same, if we sort the digits in ...

  6. iOS中为网站添加图标到主屏幕以及增加启动画面

    虽然没有能力开发Native App,但还是可以利用iOS中Safari浏览器的特性小小的折腾一下,做一个伪Web App满足下小小的虚荣心的. 既然是在iOS中的Safari折腾的,那么代码中利用到 ...

  7. Head First设计模式悟道

    暂时包括 策略模式,观察者,装饰模式,工厂模式,抽象工厂模式,后续会继续补充中,纯属个人总结用,不喜勿喷, 源代码见: 传送门 public class NYPizzaIngredientFactor ...

  8. Windows.Andy.Code4App.dll Win8.1/WP8.1通用类库@ver1.0.0

    直接入题! Win8.1和WP8.1眼下已经渐渐融为一体,WP8.1不断向Win8.1靠拢,虽然一些方法上WP8.1和Win8.1不同(ps:WP8.1和Win8.1的不同之处),但大部分还是相同的. ...

  9. java指令集

    0x00 nop      什么都不做 0x01 aconst_null 将null推送至栈顶 0x02 iconst_m1   将int型-1推送至栈顶 0x03 iconst_0   将int型0 ...

  10. 制作输入框(Input)

    怎样判断是否应当使用输入框 输入框,就是用户可以自由输入文本的地方.当需要判断是否需要使用输入框时,可以遵循一条原则:凡是需要用户自主输入文本的地方,几乎都必须使用输入框. 输入框的常见用法:输入登录 ...