• JS 中 对象 基础认识


    俗话说:“万物皆对象”,在 Javascript  中除了原始值几乎所有的东西都可以看做对象:

    • 布尔是对象( new 关键词定义)
    • 数字是对象( new 关键词定义)
    • 字符串是对象( new 关键词定义)
    • 日期永远都是对象
    • 算术永远都是对象
    • 正则表达式永远都是对象
    • 数组永远都是对象
    • 函数永远都是对象
    • 对象永远都是对象

     

    一、什么是原始值

    Javascript 中原始值是指没有属性和方法的值。

    原始数据类型(拥有原始值的类型):

    • string
    • number
    • boolean
    • null
    • undefined

     

    二、什么是对象

    “万物皆对象”,在 Java 中对象的定义:对象就是存在的具体实体,具有明确定义的状态和行为,是面向对象编程的核心,用来描述现实世界中的实体,为计算机应用程序提供实体基础,也是完成特定任务一个封装。

    Javascript 中的对象是包含变量的变量,但是对象能够包含很多值。可以理解为:对象是属性和方法的命名值得容器 

    var person = {firstName:"Coder", lastName:"Yarn", age:22, eyeColor:"black"};

     

    对象命名值 对象属性

    属性
    firstName Coder
    lastName Yarn
    age 22
    eyeColor black

     

    对象方法:方法是可以在对象上执行的动作,即在对象身上发生的事件

    属性 方法
    fullName function() {return this.firstName + " " + this.lastName;}

     

    三、对象的创建

    创建对象主要三种方法:

    • 对象字面量;
      var person = {
          firstName:"Coder", 
          lastName:"Yarn", 
          age:22, 
          eyeColor:"black",
          fullName:function() {
              return this.firstName + " " + this.lastName;
          },
      };
    • new object();
      let person = new Object();
          person.firstName = "Coder"; 
          person.lastName = "Yarn";
          person.age = 22; 
          person.eyeColor = "black";
          person.fullName = function() {
              return this.firstName + " " + this.lastName;
          };
    • 自定义构造函数;
      function Person(){
          constructor(firstName,lastName,age,eyeColor){
              this.firstName = firstName;
              this.lastName = lastName;
              this.age = age;
              this.eyeColor = eyeColor;
          };
          this.fullName = function() {
              return this.firstName + " " + this.lastName;
          };
      };
      
      var person1 = new Person("Coder","Yarn",22,"black");
      
      console.log(personl);
      console.log(person1.fullName());
      
      //打印的结果
      Coder
      Yarn
      22
      black
      Coder Yarn

     

    注意:出于简易性、可读性和执行速度的考虑不会使用第二种方法(new Object()),而是使用第一种创建方法(对象字面量方法)。

    在 ES5 中为了简化代码,将对象共同拥有的属性和方法都放在同一个函数中,这个函数就是我们自定义的构造函数,即 Java 中的类,然后可以通过 new 一个实例对象来使用这些属性和方法,不过这种方法特别地浪费内存。 ES6 后几乎都使用对象字面量方法来创建对象。

  • 相关阅读:
    国际刑事法院系统遭网络间谍攻击
    JS构造函数与class类中的封装、继承和多态
    Java8新特性:stream()流的巧妙用法总结
    1-6月中国ADAS供应商占比9% 又一家零部件巨头全面布局智驾新赛道
    综合实验高级网络—— 配置三层 热备等网络技术
    【JavaEE】初识网络
    【Web】第三次
    Juc并发编程12——2万字深入源码:线程池这篇真的讲解的透透的了
    php不重新编译,添加模块
    如何实现 MySQL 增删改查操作
  • 原文地址:https://www.cnblogs.com/cyy22321-blog/p/16215385.html