zoukankan      html  css  js  c++  java
  • 浅析JavaScript访问对象属性和方法及区别

    属性是一个变量,用来表示一个对象的特征,如颜色、大小、重量等;方法是一个函数,用来表示对象的操作,如奔跑、呼吸、跳跃等。

    在JavaScript中通常使用”."运算符来存取对象的属性的值。或者使用[]作为一个关联数组来存取对象的属性。

    对象的属性和方法统称为对象的成员。

    访问对象的属性

    在JavaScript中,可以使用“ . ”和“ [ ] ”来访问对象的属性。

    1. 使用“ . ”来访问对象属性

    语法:

        objectName.propertyName

    其中,objectName 为对象名称,propertyName为属性名称。

    2. 使用“ [ ] ”来访问对象属性

    语法:

        objectName[propertyName]

    其中,objectName 为对象名称,propertyName为属性名称。

    访问对象的方法

    在JavaScript中,只能使用“ . ”来访问对象的方法。

    语法:

        objectName.methodName()

    其中,objectName 为对象名称,methodName() 为函数名称。

    【例5-1】创建一个Person类:

    function Person() {
      this.name=" 张三 "; // 定义一个属性 name
      this.sex=""; // 定义一个属性 sex
      this.age=22; // 定义一个属性 age
      this.say=function(){ // 定义一个方法 say()
        return "嗨!大家好,我的名字是 " + this.name + " ,性别是 " + this.sex + ",今年 " + this.age +"岁!";
      }
    }
    var zhangsan=new Person();
    alert("姓名:"+zhangsan.name); // 使用“.”来访问对象属性
    alert("性别:"+zhangsan.sex);
    alert("年龄:"+zhangsan["age"]); // 使用“[ ]”来访问对象属性
    alert(zhangsan.say);  // 使用“.”来访问对象方法

    PS:浅析对象访问属性的"."和"[]"方法区别

    在JavaScript中通常使用”."运算符来存取对象的属性的值。或者使用[]作为一个关联数组来存取对象的属性。但是这两种方式有什么区别了?

    例如,读取object中的property属性值:

        object.property

        object['property']

    以上两种方式都可以实现属性的存取。

    1.语法方面的区别

    点表示法的对象的属性名是标识符,而后者的属性名则是一个字符串。

    2.灵活性方面的区别

    在JavaScript编写程序中,可以为对象创建任意数目的属性。但使用”.“运算符来存取一个对象的属性时,属性名是用标识符表示的。而在JavaScript程序中,标识符必须被逐字地输入,它们不是一种数据类型,因此程序不能对其操作。也就是说,标识符是静态的,在程序中必须对其进行硬编码。

    而使用数组[]表示法来存取一个对象的属性时,属性名是用字符串表示的。字符串是JavaScript的一种数据类型,因此可以在程序运行中操作并创建它们。

    3.性能方面区别

    数组[]表示法在存取属性值时会进行表达式运行。而点表示法是直接存取属性值,理论上执行效率会比数组表示法高。性能方面其实可以忽略。

    某些场景必须用到数组表示法来动态存取属性值,这个是点表示法无法做到的。

    总的来说,这两种方法区别上不大,都有对应的使用场景。点表示法一般作为静态对象使用时来存取属性。而数组表示法在动态存取属性时就非常有用。

  • 相关阅读:
    Rewrite the master page form action attribute in asp.net 2.0
    Using Output Cache
    An invalid character was found in text content!
    Microsoft Football Scoreboard
    A typical ASP.NET 2.0 Configuration Settings
    Visual Studio 2005 Web Application Projects Released!
    Test Driven Development with Visual Studio 2005 Team System
    How to pass a parameter to HyperLink in GridView/DataList
    MS的一个BUG折腾我几个小时!
    Create builtin tables in your own database to handle exceptions, Part 2
  • 原文地址:https://www.cnblogs.com/SofuBlue/p/8143938.html
Copyright © 2011-2022 走看看