js对象与打印对象分析比较


Posted in Javascript onApril 23, 2013

JS对象介绍:

一,基本概念

1,自定义对象。
根据JS的对象扩展机制,用户可以自定义JS对象,这与Java语言有类似的地方。
与自定义对象相对应的是JS标准对象,例如Date、Array、Math等等。
2,原型(prototype)
在JS中,这是一种创建对象属性和方法的方式,通过prototype可以为对象添加新的属性和方法。
通过prototype我们可以为JS标准对象添加新的属性和方法,例如对于String对象,我们可以为其添加一个新的方法trim()。
与严格的编程语言(例如Java)不同,我们可以在运行期间为JS对象动态添加新的属性。

二,语法规则

1,对象创建方式

1)对象初始化器方式

格式:objectName = {property1:value1, property2:value2,…, propertyN:valueN}
property是对象的属性
value则是对象的值,值可以是字符串、数字或对象三者之一
例如: var user={name:“user1”,age:18};
    var user={name:“user1”,job:{salary:3000,title:programmer}
以这种方式也可以初始化对象的方法,例如:
    var user={name:“user1”,age:18,getName:function(){
                return this.name;
          }        
    }
后面将以构造函数方式为重点进行讲解,包括属性和方法的定义等等,也针对构造函数的方式进行讲解。

2)构造函数方式

编写一个构造函数,并通过new方式来创建对象,构造函数本可以带有构造参数
例如:

function User(name,age){
          this.name=name;
          this.age=age;
          this.canFly=false;
    }
    var use=new User();

2,定义对象属性

1)JS中可以为对象定义三种类型的属性:私有属性、实例属性和类属性,与Java类似,私有属性只能在对象内部使用,实例属性必须通过对象的实例进行引用,而类属性可以直接通过类名进行引用。

2)私有属性定义
私有属性只能在构造函数内部定义与使用。
语法格式:var propertyName=value;
例如:

function User(age){
           this.age=age;
           var isChild=age<12;
           this.isLittleChild=isChild;
    }
    var user=new User(15);
    alert(user.isLittleChild);//正确的方式
    alert(user.isChild);//报错:对象不支持此属性或方法

3)实例属性定义,也存在两种方式:
prototype方式,语法格式:functionName.prototype.propertyName=value
this方式,语法格式:this.propertyName=value,注意后面例子中this使用的位置
上面中value可以是字符创、数字和对象。
例如:
function User(){ }
User.prototype.name=“user1”;
User.prototype.age=18;
var user=new User();
alert(user.age);
—————————————?
function User(name,age,job){
         this.name=“user1”;
         this.age=18;
         this.job=job;
    }
    alert(user.age);

3)类属性定义
语法格式:functionName.propertyName=value
例如:
function User(){ }
User.MAX_AGE=200;
User.MIN_AGE=0;
alert(User.MAX_AGE);

参考JS标准对象的类属性:
Number.MAX_VALUE //最大数值 Math.PI //圆周率

4)对于属性的定义,除了上面较为正规的方式外,还有一种非常特别的定义方式,语法格式: obj[index]=value
例子:

     function User(name){
             this.name=name;
             this.age=18;
             this[1]=“ok”;
             this[200]=“year”;
     }
     var user=new User(“user1”);
     alert(user[1]);

     在上面例子中,要注意:不同通过this[1]来获取age属性,也不能通过this[0]来获取name属性,即通过index方式定义的必须使用index方式来引用,而没有通过index方式定义的,必须以正常方式引用

3,定义对象方法

1)JS中可以为对象定义三种类型的方法:私有方法、实例方法和类方法,与Java类似:
私有方法只能在对象内部使用
实例方法必须在对象实例化后才能使用
类方法可以直接通过类名去使用
注意:方法的定义不能通过前面所说的index方式进行。
2)定义私有方法
私有方法必须在构造函数体内定义,而且只能在构造函数体内使用。
语法格式:function methodName(arg1,…,argN){ }
例如:

function User(name){
          this.name=name;
          function getNameLength(nameStr){
              return nameStr.length;
          }
          this.nameLength=getNameLength(this.name);   
    }

3)定义实例方法,目前也可以使用两种方式:
prototype方式,在构造函数外使用,语法格式:
functionName.prototype.methodName=method;
或者
functionName.prototype.methodName=function(arg1,…,argN){};
this方式,在构造函数内部使用,语法格式:
this.methodName=method;
或者
this.methodName=function(arg1,…,argN){};
上面的语法描述中,method是外部已经存在的一个方法,methodName要定义的对象的方法,意思就是将外部的一个方法直接赋给对象的某个方法。
以function(arg1,…,argN){}的方式定义对象方法是开发人员应该掌握的。

定义实例方法的一些例子:例子1

function User(name){
       this.name=name;
       this.getName=getUserName;
       this.setName=setUserName;
}
function getUserName(){
       return this.name;
}
Function setUserName(name){
       this.name=name;
}

定义实例方法的一些例子:例子2
function User(name){
       this.name=name;
       this.getName=function(){
               return this.name;
       };
       this.setName=function(newName){
               this.name=newName;
       };
}

定义实例方法的一些例子:例子3
function User(name){
       this.name=name;
}
User.prototype.getName=getUserName;
User.prototype.setName=setUserName();
function getUserName(){
       return this.name;
}
Function setUserName(name){
       this.name=name;
}

定义实例方法的一些例子:例子4
function User(name){
       this.name=name;
}
User.prototype.getName=function(){
       return this.name;
};
User.prototype.setName=function(newName){
       this.name=newName;
};

4)定义类方法
类方法需要在构造函数外面定义,可以直接通过构造函数名对其进行引用。
语法格式:
functionName.methodName=method;
或者
functionName.methodName=function(arg1,…,argN){};
例子:
function User(name){
            this.name=name;
    }
    User.getMaxAge=getUserMaxAge;
    function getUserMaxAge(){
           return 200;
    }
    或者
    User.getMaxAge=function(){return 200;};
    alert(User.getMaxAge());

4,属性与方法的引用

1)从可见性上说:
私有属性与方法,只能在对象内部引用。
实例属性与方法,可以在任何地方使用,但必须通过对象来引用。
类属性与方法,可以在任何地方使用,但不能通过对象的实例来引用(这与Java不同,在Java中静态成员可以通过实例来访问)。
2)从对象层次上说:
与Java bean的引用类似,可以进行深层次的引用。
几种方式:
简单属性:obj.propertyName
对象属性:obj.innerObj.propertyName
索引属性:obj.propertyName[index]
对于更深层次的引用与上面类似。
3)从定义方式上说:
通过index方式定义的属性,必须通过index方式才能引用。
通过非index方式定义的属性,必须通过正常的方式才能引用。
另外注意:对象的方法不能通过index方式来定义。

5,属性与方法的动态增加和删除
1)对于已经实例化的对象,我们可以动态增加和删除它的属性与方法,语法如下(假定对象实例为obj):
动态增加对象属性
obj.newPropertyName=value;
动态增加对象方法
    obj.newMethodName=method或者=function(arg1,…,argN){}
动态删除对象属性
    delete obj.propertyName
动态删除对象方法
    delete obj.methodName

2)例子:

    function User(name){
             this.name=name;
             this.age=18;
    }
    var user=new User(“user1”);
    user.sister=“susan”;
    alert(user.sister);//运行通过
    delete user.sister;
    alert(user.sister);//报错:对象不支持该属性
    user.getMotherName=function(){return “mary”;}
    alert(user.getMotherName());//运行通过
    delete user.getMotherName;
    alert(user.getMotherName());//报错:对象不支持该方法

JS对象打印:

<script type="text/javascript">
 function aaa(){
     alert('111');
 } p = {'a':1,'b':2};
 window.onload=function(){
     for(var i in p){
         document.write(i+':');
         document.write(p[i]+'<br />');
     }
 }
 </script>
Javascript 相关文章推荐
JQuery1.6 使用方法三
Nov 23 Javascript
jquery 插件学习(四)
Aug 06 Javascript
jquery文本框中的事件应用以输入邮箱为例
May 06 Javascript
node.js中的http.get方法使用说明
Dec 14 Javascript
node.js中的fs.fstatSync方法使用说明
Dec 15 Javascript
jquery.mousewheel实现整屏翻屏效果
Aug 30 Javascript
jQuery Ajax 加载数据时异步显示加载动画
Aug 01 Javascript
JavaScript生成验证码并实现验证功能
Sep 24 Javascript
BootStrapValidator初使用教程详解
Feb 10 Javascript
浅谈js使用in和hasOwnProperty获取对象属性的区别
Apr 27 Javascript
VSCode 配置React Native开发环境的方法
Dec 27 Javascript
WebPack配置vue多页面的技巧
May 15 Javascript
你必须知道的Javascript知识点之&quot;深入理解作用域链&quot;的介绍
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;字面量和对应类型&quot;说明介绍
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;单线程事件驱动&quot;的使用
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;this指针&quot;的应用
Apr 23 #Javascript
jquery清空textarea等输入框实现代码
Apr 22 #Javascript
js计算精度问题小结
Apr 22 #Javascript
基于javascipt-dom编程 table对象的使用
Apr 22 #Javascript
You might like
PHP下利用shell后台运行PHP脚本,并获取该脚本的Process ID的代码
2011/09/19 PHP
Laravel中unique和exists验证规则的优化详解
2018/01/28 PHP
TP5框架实现上传多张图片的方法分析
2020/03/29 PHP
自定义一个jquery插件[鼠标悬浮时候 出现说明label]
2011/06/27 Javascript
HTTP 304错误的详细讲解
2013/11/13 Javascript
js禁止回车提交表单的示例代码
2013/12/23 Javascript
JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
2014/10/17 Javascript
JavaScript的类型、值和变量小结
2015/07/09 Javascript
apply和call方法定义及apply和call方法的区别
2015/11/15 Javascript
Bootstrap教程JS插件滚动监听学习笔记分享
2016/05/18 Javascript
js无法获取到html标签的属性的解决方法
2016/07/26 Javascript
echarts3 使用总结(绘制各种图表,地图)
2017/01/05 Javascript
微信小程序 下拉菜单简单实例
2017/04/13 Javascript
vue+axios实现文件下载及vue中使用axios的实例
2018/09/21 Javascript
基于Koa2写个脚手架模拟接口服务的方法
2018/11/27 Javascript
解决vue组件props传值对象获取不到的问题
2019/06/06 Javascript
JS秒杀倒计时功能完整实例【使用jQuery3.1.1】
2019/09/03 jQuery
vue中npm包全局安装和局部安装过程
2019/09/03 Javascript
[58:46]OG vs NAVI 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python多进程机制实例详解
2015/07/02 Python
Apache如何部署django项目
2017/05/21 Python
python脚本替换指定行实现步骤
2017/07/11 Python
解决python3中解压zip文件是文件名乱码的问题
2018/03/22 Python
python实现决策树ID3算法的示例代码
2018/05/30 Python
python图像处理模块Pillow的学习详解
2019/10/09 Python
pytorch 自定义参数不更新方式
2020/01/06 Python
python将图片转base64,实现前端显示
2020/01/09 Python
css3 盒模型以及box-sizing属性全面了解
2016/09/20 HTML / CSS
美国知名平价彩妆品牌:e.l.f. Cosmetics
2017/11/20 全球购物
大学学年自我鉴定
2013/10/28 职场文书
2014学雷锋活动心得体会
2014/03/10 职场文书
小学生家长寄语
2014/04/02 职场文书
学校联谊协议书
2014/09/16 职场文书
领导班子党的群众路线教育实践活动对照检查材料
2014/09/25 职场文书
2015年中秋晚会主持词
2015/07/01 职场文书
普希金的诗歌赏析(3首)
2019/08/20 职场文书