Hướng dẫn javascript static variable in class - biến tĩnh javascript trong lớp

Từ khóa static xác định một phương thức hoặc thuộc tính tĩnh cho một lớp hoặc khối khởi tạo tĩnh lớp [xem liên kết để biết thêm thông tin về việc sử dụng này]. Cả các phương thức tĩnh và tính chất tĩnh đều không thể được gọi trên các trường hợp của lớp. Thay vào đó, họ được gọi vào chính lớp.static keyword defines a static method or property for a class, or a class static initialization block [see the link for more information about this usage]. Neither static methods nor static properties can be called on instances of the class. Instead, they're called on the class itself.

Các phương thức tĩnh thường là các hàm tiện ích, chẳng hạn như các hàm để tạo hoặc nhân bản các đối tượng, trong khi các thuộc tính tĩnh rất hữu ích cho bộ nhớ cache, cấu hình cố định hoặc bất kỳ dữ liệu nào khác mà bạn không cần được sao chép trên các trường hợp.

Lưu ý: Trong bối cảnh của các lớp, Nội dung tài liệu web MDN sử dụng các thuộc tính và trường thuật ngữ có thể thay thế cho nhau. In the context of classes, MDN Web Docs content uses the terms properties and fields interchangeably.

Thử nó

Cú pháp

static methodName[] { /* … */ }
static propertyName [= value];

// Class static initialization block
static {

}

Ví dụ

Sử dụng các thành viên tĩnh trong các lớp học

Ví dụ sau đây cho thấy một số điều:

  1. Làm thế nào một thành viên tĩnh [phương thức hoặc thuộc tính] được xác định trên một lớp.
  2. Rằng một lớp với một thành viên tĩnh có thể được phân lớp phụ.
  3. Làm thế nào một thành viên tĩnh có thể và không thể được gọi.

class Triple {
  static customName = 'Tripler';
  static description = 'I triple any number you provide';
  static calculate[n = 1] {
    return n * 3;
  }
}

class SquaredTriple extends Triple {
  static longDescription;
  static description = 'I square the triple of any number you provide';
  static calculate[n] {
    return super.calculate[n] * super.calculate[n];
  }
}

console.log[Triple.description];            // 'I triple any number you provide'
console.log[Triple.calculate[]];            // 3
console.log[Triple.calculate[6]];           // 18

const tp = new Triple[];

console.log[SquaredTriple.calculate[3]];    // 81 [not affected by parent's instantiation]
console.log[SquaredTriple.description];     // 'I square the triple of any number you provide'
console.log[SquaredTriple.longDescription]; // undefined
console.log[SquaredTriple.customName];      // 'Tripler'

// This throws because calculate[] is a static member, not an instance member.
console.log[tp.calculate[]];                // 'tp.calculate is not a function'

Gọi các thành viên tĩnh từ một phương thức tĩnh khác

Để gọi một phương thức hoặc thuộc tính tĩnh trong một phương thức tĩnh khác của cùng một lớp, bạn có thể sử dụng từ khóa this.

class StaticMethodCall {
  static staticProperty = 'static property';
  static staticMethod[] {
    return `Static method and ${this.staticProperty} has been called`;
  }
  static anotherStaticMethod[] {
    return `${this.staticMethod[]} from another static method`;
  }
}
StaticMethodCall.staticMethod[];
// 'Static method and static property has been called'

StaticMethodCall.anotherStaticMethod[];
// 'Static method and static property has been called from another static method'

Gọi các thành viên tĩnh từ một hàm tạo lớp và các phương thức khác

Các thành viên tĩnh không thể truy cập trực tiếp bằng cách sử dụng từ khóa this từ các phương thức không tĩnh. Bạn cần gọi cho họ bằng tên lớp: CLASSNAME.STATIC_METHOD_NAME[] / CLASSNAME.STATIC_PROPERTY_NAME hoặc bằng cách gọi phương thức là thuộc tính của constructor:

class Triple {
  static customName = 'Tripler';
  static description = 'I triple any number you provide';
  static calculate[n = 1] {
    return n * 3;
  }
}

class SquaredTriple extends Triple {
  static longDescription;
  static description = 'I square the triple of any number you provide';
  static calculate[n] {
    return super.calculate[n] * super.calculate[n];
  }
}

console.log[Triple.description];            // 'I triple any number you provide'
console.log[Triple.calculate[]];            // 3
console.log[Triple.calculate[6]];           // 18

const tp = new Triple[];

console.log[SquaredTriple.calculate[3]];    // 81 [not affected by parent's instantiation]
console.log[SquaredTriple.description];     // 'I square the triple of any number you provide'
console.log[SquaredTriple.longDescription]; // undefined
console.log[SquaredTriple.customName];      // 'Tripler'

// This throws because calculate[] is a static member, not an instance member.
console.log[tp.calculate[]];                // 'tp.calculate is not a function'
0 /
class Triple {
  static customName = 'Tripler';
  static description = 'I triple any number you provide';
  static calculate[n = 1] {
    return n * 3;
  }
}

class SquaredTriple extends Triple {
  static longDescription;
  static description = 'I square the triple of any number you provide';
  static calculate[n] {
    return super.calculate[n] * super.calculate[n];
  }
}

console.log[Triple.description];            // 'I triple any number you provide'
console.log[Triple.calculate[]];            // 3
console.log[Triple.calculate[6]];           // 18

const tp = new Triple[];

console.log[SquaredTriple.calculate[3]];    // 81 [not affected by parent's instantiation]
console.log[SquaredTriple.description];     // 'I square the triple of any number you provide'
console.log[SquaredTriple.longDescription]; // undefined
console.log[SquaredTriple.customName];      // 'Tripler'

// This throws because calculate[] is a static member, not an instance member.
console.log[tp.calculate[]];                // 'tp.calculate is not a function'
1

class StaticMethodCall {
  constructor[] {
    console.log[StaticMethodCall.staticProperty]; // 'static property'
    console.log[this.constructor.staticProperty]; // 'static property'
    console.log[StaticMethodCall.staticMethod[]]; // 'static method has been called.'
    console.log[this.constructor.staticMethod[]]; // 'static method has been called.'
  }

  static staticProperty = 'static property';
  static staticMethod[] {
    return 'static method has been called.';
  }
}

Thông số kỹ thuật

Sự chỉ rõ
Đặc tả ngôn ngữ Ecmascript # Sec-Class-Deellitions
# sec-class-definitions

Tính tương thích của trình duyệt web

Bảng BCD chỉ tải trong trình duyệt

Xem thêm

Các lớp có thể có các biến tĩnh?

Các biến lớp còn được gọi là các biến tĩnh và chúng được khai báo bên ngoài một phương thức, với sự trợ giúp của từ khóa 'tĩnh'. Biến tĩnh là một biến là phổ biến cho tất cả các trường hợp của lớp. Một bản sao của biến được chia sẻ giữa tất cả các đối tượng., and they are declared outside a method, with the help of the keyword 'static'. Static variable is the one that is common to all the instances of the class. A single copy of the variable is shared among all objects.

Một lớp học có thể tĩnh trong javascript?

Từ khóa tĩnh xác định một phương thức hoặc thuộc tính tĩnh cho một lớp hoặc khối khởi tạo tĩnh lớp [xem liên kết để biết thêm thông tin về việc sử dụng này].Cả các phương thức tĩnh và tính chất tĩnh đều không thể được gọi trên các trường hợp của lớp.Thay vào đó, họ được gọi vào chính lớp. [see the link for more information about this usage]. Neither static methods nor static properties can be called on instances of the class. Instead, they're called on the class itself.

Chúng ta có thể sử dụng biến tĩnh trong JavaScript không?

Chúng ta có thể sử dụng biến tĩnh ở bất cứ đâu.Giá trị của biến tĩnh có thể được chỉ định lại, không giống như biến không đổi.Tại sao chúng tôi tạo một biến tĩnh trong JavaScript: Chúng tôi tạo một biến tĩnh trong JavaScript để ngăn chặn sự sao chép, cấu hình cố định và nó cũng hữu ích cho bộ đệm.. The value of the static variable can be reassigned, unlike the constant variable. Why we create a static variable in JavaScript: We create a static variable in JavaScript to prevent replication, fixed-configuration, and it is also useful for caches.

Tôi có thể khai báo biến trong lớp JavaScript không?

Để khai báo một biến trong một lớp, nó cần phải là một thuộc tính của lớp hoặc, như bạn đã làm như vậy, phạm vi trong một phương thức trong lớp.Đó là tất cả về phạm vi và các biến không được hỗ trợ trong định nghĩa phạm vi của một lớp.it needs to be a property of the class or, as you did so, scoped within a method in the class. It's all about scoping and variables are not supported in the scope definition of a class.

Bài Viết Liên Quan

Chủ Đề