(思考)Ajax第一篇 JavaScript之引用类型

(觉得自己一直思考太少且深度不够,所以加上这个前缀提醒自己-思维才是核心竞争力。)
一、JavaScript之面向对象,读书笔记加上自己的一些思考。Javascript的对象分为两种,一种表示的是已命名的值的无需集合;另一种表示的是有编号的值的有序结合即Array。
引用类型是一种数据结构,用来将数据与功能组成在一起。
有必要解释一下javascript中的对象:即一些”名-值“对(named values)所组成的集合。需要注意的是name只能是string类型,而value类型不限。
[b]Object[/b]:已命名的数据集合
[b]创建方式[/b]有两种,第一种构造函数创建:

var person =new Object();
person.name ="Yancy";
person.sex ="man";
person.age =25;

第二种Object Literals创建:(用来简化属性的赋值过程)

var person = {
name : "Yancy";
sex : "man";
age : 25
};

需要注意的有三点:1.属性名与值之间用colon连接;2.最后一个属性后没有semicolon; 3.close brace后有semicolon,仅仅是句子结束后的sign而已。
用Literals传参数:

function displayinfo(args){
var output ="";
if(typeof args.name ==“string”){
output +="Name:"+args.name+"\n";
}
if(typeof args.sex==“string”){
output +="Sex:"+args.sex+"\n";
}
if(typeof args.age =="number"){
output +="Age:" +args.age +"\n"
}
alert(output);
}
displayinfo({
name : "Yancy";
sex : "man";
age : 25
});
displayinfo({
name : "Shane"
});

对Object Literals的理解,其实并没有所谓的对象,仅仅是把”named values“结合在了一起而已。
[b]Array[/b],[b]Data[/b],[b]Number[/b],[b]Boolean[/b],[b]String[/b]类型很容易,不再赘述;[b]RegExp[/b]是no essential的,用时再看。
注意的是:delete操作符用以删除对象中的某个属性,
in操作符用以判断某个属性是否存在并可以使用
[b]Function[/b]:函数实际上是对象,每个函数都是Functin类型的实例,于其他引用类型一样具有属性和方法,因此函数名实际上是一个指向函数对象的指针.
创建方式:

//function declare
function sum(num1,num2){
return num1 +num2;
}
//function expression
var sum =function (num1,num2){
return num1 +num2;
};
//another style
var sum =new Function("num1","num2","return num1 +num2");//no recommend

注意function declare是解析器首先读取的,而function expression是在执行到它时才会读取的。Function内部有两个特殊的对象arguments和this,arguments是一个类数组对象,保存着传入Function的所有参数,arguments还有一个callee属性,指向拥有这个arguments对象的函数;this代表函数在执行时所处的环境对象;而Function自己作为一个对象,也有属性和方法。每个Function都有两个属性length和prototype,两个方法apply和call。
length:代表的是所传参数的个数;
prototype:通过对象实例访问的区域,相当于静态变量;
apply和call:在特定的作用域中调用函数,注意第一个参数是作用域;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值