Java script 中的面向对象
-
对象
对象是Javascript的基本数据类型,对象是一种复合值,将很多的键值对聚合在一起使用。对象可看做是属性的无序集合,每个属性都是一个名/值对。属性名其实是一个字符串。我们可以把对象看做是字符串到值的映射。
-
创建对象
例子代码如下:
<script type="text/javascript" language="JavaScript">
//创建一个对象o 有两个属性 x y
var o={
x:10,//注意:名/值之间用冒号:隔开多个名值对之间用逗号间隔
y:20//整个映射表要用花括号括起来
};
var o1={
}//创建一个空对象
//对象中的值可以引用其他对象的值
var o2={
x:o.x-1,
y:o.y
author:{
fristname:"lisi",
lastname:"zhangsan"
}
}
</script>
-
通过new 创建对象
var o3=new Object();//创建一个空对象和{}一样
var a=new Array();//创建一个空数组和[]一样
var d=new Date();//创建一个表示当前日期的对象
var r=new RegExp("js");//创建一个进行模式模式匹配的RegExp对象
-
原型
每一个对象都是从原型中继承而来的
通过Javascript代码 object.prototype获得对原型对象的引用
通过关键字new和构造函数调用创建的对象的原型都是构造函数的prototype属性的值
因此使用{}创建的对象一样 通过new object()创建的对象也继承来自于Array.prototype,通过new Date()创建的对象的原型就是Date.prototype.
Object.prototype没有原型
4.通过Object.create()创建对象
Object.create()是一个静态的函数,不是提供给某个对象调用的方法。
只需传入所需的的原型对象即可。
var a1=Object.create({x:10,y:12});
二.对象属性的设置
可以通过点.或者方括号[]运算符来取属性的值
注意:方括号内必须是一个计算结果为字符串的表达式
var 0_x=o2.x;
var o_author=02["author"];
同样可以通过这种方式对对象设置属性值
o2.x=10;
o2["y"]=20;
三、函数对象
可以使用function关键字定义一个函数,并为每个函数指定一个函数名,通过函数名来进行调用。在javascript解释执行的时候,函数都是被维护为一个对象,就是函数对象。
function myfunction(a,b){
return a+b;
}
等价于
var myfunction = new Function("a","b","return a+b");
另外
var i = function(a,b){
return a+b;
}(1,2)
这样的写法就是创建完函数后马上执行。
再有,function funcName(){}等价于
var funcName = function(){}