js6类和对象

[javascript] view plain copy

  1. // 第一种:对象
  2. var person = {};// 或者var obj = new Object();
  3. person.name = "king";
  4. person.age = 20;
  5. person.Introduce = function () {
  6. alert("My name is " + this.name + ". My age is " + this.age);
  7. };
  8. person.Introduce();
  9. // 第二种:json格式的对象
  10. var person = {
  11. name: "king",
  12. age: 20,
  13. Introduce: function () {
  14. alert("My name is " + this.name + ". My age is " + this.age);
  15. }
  16. };
  17. person.Introduce();
  18. alert(person.name);// king
  19. // 第三种(1):类,类似于默认构造函数
  20. var Person = function () {
  21. this.name = "king";
  22. this.age = 20;
  23. this.Introduce = function () {
  24. alert("My name is " + this.name + ". My age is " + this.age);
  25. };
  26. };
  27. var person = new Person();// 或者var person = Person();
  28. person.Introduce();
  29. alert(person.name);// 输出:king
  30. alert(person["name"]);// 也可以使用json的访问方式,说明使用function定义类与第二种是等效的
  31. alert(person.age);// 输出:20
  32. // 第三种(2):区别仅在于第一行的声明
  33. function Person () {
  34. this.name = "king";
  35. this.age = 20;
  36. this.Introduce = function () {
  37. alert("My name is " + this.name + ". My age is " + this.age);
  38. };
  39. };
  40. var person = new Person();
  41. person.Introduce();
  42. alert(person.name);// 输出:king
  43. alert(person.age);// 输出:20
  44. // 第四种(1):可定制的类,类似构造函数
  45. var Person = function (name, age) {
  46. this.name = name;
  47. this.age = age;
  48. this.Introduce = function () {
  49. alert("My name is " + this.name + ". My age is " + this.age);
  50. };
  51. };
  52. var person = new Person("king", 20);
  53. person.Introduce();
  54. alert(person.name);// 输出:king
  55. alert(person.age);// 输出:20
  56. // 第四种(2):
  57. function Person (name, age) {
  58. this.name = name;
  59. this.age = age;
  60. this.Introduce = function () {
  61. alert("My name is " + this.name + ". My age is " + this.age);
  62. };
  63. };
  64. var person = new Person("king", 20);
  65. person.Introduce();
  66. alert(person.name);// 输出:king
  67. alert(person.age);// 输出:20
  68. // 第五种:变量的封装,将其改为私有。采用了闭包。
  69. // 在function中用this引用当前对象,通过对属性的赋值来声明属性。即this定义的为公有
  70. // 如果用var声明变量,则该变量为局部变量,只允许在类定义中调用。即var定义的为私有,不用var则为全局
  71. var Person = function (name, age) {
  72. var name = name;
  73. var age = age;
  74. this.GetName = function () {
  75. return name;
  76. }
  77. this.GetAge = function () {
  78. return age;
  79. }
  80. this.Introduce = function () {
  81. alert("My name is " + name + ". My age is " + age);
  82. };
  83. };
  84. var person = new Person("king", 20);
  85. alert(person["name"]);// undefined
  86. alert(person.GetName());// king
  87. // 第五种(2):可参考第三种(2)和第四种(2)
  88. // 第六种(1):在函数体中创建一个对象(使用第二种),声明其属性再返回
  89. function Person() {
  90. var obj =
  91. {
  92. ‘age‘:20,
  93. ‘name‘:‘king‘
  94. };
  95. return obj;
  96. }
  97. var person = new Person();
  98. alert(person.age);// 输出:20
  99. alert(person.name);// 输出:king
  100. // 第六种(2):函数体内创建对象时使用第一种方法
  101. function Person() {
  102. var obj = new Object();
  103. obj.age = 20;
  104. obj.name = ‘king‘;
  105. return obj;
  106. }
  107. var person = new Person();
  108. alert(person.age);// 输出:20
  109. alert(person.name);// 输出:king

小结:上述第一种、第二种方法为直接创建一个对象字面量。第二种到第六种方法相当于提供了类,使用new操作符(可省略)创建对象实例。

时间: 2024-08-26 04:46:26

js6类和对象的相关文章

Java 第七章 类和对象 笔记

一.对象的特征--类的属性 每个对象的每个属性都有特定的值 对象的操作--类的方法 二.封装:对象同时具有属性和方法两项特性.     对象的属性和方法通常被封装在一起,共同体现事物的特性,     二者相辅相成,不能分割. 三.类和对象的区别:     类:抽象的概念,是一个模子,确定了对象的属性和方法.    对象:能够看得见摸得着的实物.具有静态和动态特征. 四.定义类的步骤:     1.定义类名      2.定义类的属性 访问修饰符 属性类型 属性名称=默认值:     3.定义类的

类与对象

1.1 类和对象的关系   为什么要采用面向对象思想进行程序设计与开发 1.可以实现代码的复用 2.符合人思考的方式   类和对象的定义 1.类的定义:用class关键修饰的叫做类 2.对象的定义:类名定义的数据类型   类和对象之间关系 1.由对象归纳为类,是归纳对象共性的过程 2.在类的基础上,将状态和行为实体化为对象的过程为实例化   1.2 定义类   定义类的语法,类主要由成员变量和成员方法构成(暂不提构造函数) eg: publicclassStudent { //成员变量 intn

【编程语言】Java中的类和对象learn by Imooc

 一.什么是类和对象 * 类是模子,确定对象将会拥有的特征(属性)和方法 * 类的特点: *     类是对象的类型 *     具有相同属性和方法的一组对象的集合 * 对象的属性 *     属性-对象具有的各种特征 *     每个对象的每个属性都有用的特定值 * 对象的方法 *     方法-对象执行的操作(能干什么) * 类和对象的关系 *     类是抽象的概念,仅仅是模板 *     对象是一个你能够看得到,摸得着的具体实体 二. 如何定义Java的类 * 1.类的重要性:所有Jav

C++ 成员变量是别的类的对象

?在成员函数中,可以将this指针当参数传递,也可以返回this指针,或返回通过this指针拿到的对象 /* 成员变量是别的类的对象 */ #include <iostream> using namespace std; //日期类 class Date { int year,month,day; public: //构造方法 Date(){ cout << "Date() " << endl; } //有参 Date(int _y,int _m,i

l类与对象课后作业

java 的初始化规律 执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”. 执行类的构造函数. 类的初始化块不接收任何的参数,而且只要一创建类的对象,它们就会被执行.因此,适合于封装那些“对象创建时必须执行的代码” 当多个类之间有继承关系时,创建子类对象会导致父类初始化块的执行. 请自行编写示例代码验证以上结论. public class InitializeBlockDemo { /**   * @param args   */ public static vo

第五节 类和对象

面向对象怎么理解? 1.1 面向对象是相对面向过程而言 1.2 面向对象和面向过程都是一种思想 1.3 面向过程:强调的是功能行为 1.4 面向对象:将功能封装进对象,强调具备了功能的对象 1.5 面向对象是基于面向过程的 特点: 三个特征:封装.继承.多态 我们在开发过程中,就是在找对象进行使用,没有对象就new一个对象. 找对象:建立对象,使用对象,维护对象的关系 封装: (1)是指隐藏对象的属性和实现细节,仅对外提供公共访问方式. (2)好处:将变化隔离:便于使用:提供重用性:提高安全性

C++笔记二:类和对象

类和对象 1:面向对象基础 2: 定义类和对象 3: 类和对象的使用 4: 构造函数和析构函数 5: this指针和复制构造函数 6: static静态成员 7: const对象和const成员 8: friend友元 ---------------------------------------------------------------------------------------------------------------------- (1)面向对象基础 一.什么是面向对象程序

类、对象和包

相关概念: 对象: 对象是存在的具体实体,具有明确定义的特征和行为. 类:是具有相同属性和行为的一组对象的集合.类是对象的抽象,对象是类的实例. 包:包就是文件夹.利用包可以可以组织相关的类,同时可以做到信息的隐藏. 属性:属性用于描述对象的特征.由于属性是属于一个对象的组成,所以属性也叫成员变量.属性跟随对象放在堆空间中,书写在类中,在方法之外,随对象产生而产生,随对象销毁而销毁.特点:属性用于描述对象的特征,对象之间彼此独立,一个对象属性的变化不会影响其他对象属性的变化.属性通过对象. 的方

8.python之面相对象part.1(初识类与对象)

一.类和对象的概念. 什么是类 类就是把一类事物相同的特征和动作整合到一起就是类比如说"人"就是一个类. 什么是对象 对象就是基于类创建出来的一个具体存在的事物这个事物包含了将其创造出来的类的特征和动作. 类与对象有什么关系一切的对象都是由类产生的假如说造一支笔首先要有一个造笔的模版上帝制造人也是一样制造一个人也需要一个造人的模版这个模板就是人的"类"然后根据类的定义来产生一支支笔和一个个的人. 什么是实例化 由类产生对象的过程就是实例化类实例化的结果就是一个对象对