Sử dụng một hàm xây dựng(Constructor Function)

Một phần của tài liệu Biến trong JavaScript (Trang 56 - 57)

Tạo các đối tượng mớ

5.1.2.Sử dụng một hàm xây dựng(Constructor Function)

Bạn có thể tạo ra đối tượng của riêng mình với hai bước sau:

1. Định nghĩa kiểu của đối tượng bằng cách viết một hàm xây dựng.

2. Tạo ra một cá thể của đối tượng đó bằng toán tử new

Để định nghĩa một kiểu đối tượng, ta phải tạo ra một hàm để chỉ định rõ tên, các thuộc tính và các cách thức của kiểu đối tượng đó. Ví dụ giả sử bạn muốn tạo một kiểu đối tượng ô tô với tên là car, có các thuộc tính make, model, yearcolor, để thực hiện việc này có thể viết một hàm như sau:

function car(make, model, year ){ this.make = make

this.model = model this.year = year }

Chú ý việc sử dụng toán tử this để gán giá trị cho các thuộc tính của đối tượng phải thông qua các tham số của hàm.

Ví dụ, bạn có thể tạo một đối tượng mới kiểu car như sau:

mycar = new car(“Eagle”,”Talon TSi”,1993)

Câu lệnh này sẽ tạo ra đối tượng mycar và liên kết các giá trị được đưa vào với các thuộc tính. Khi đó giá trị của mycar.make là “Eagle”, giá trị của mycar.model Talon TSi”, và mycar.year là một số nguyên 1993....Cứ như vậy bạn có thể tạo ra nhiều đối tượng kiểu car.

Một đối tượng cũng có thể có những thuộc tính mà bản thân nó cũng là một đối tượng. Ví dụ bạn định nghĩa thêm một đối tượng khác là person như sau:

function person(name, age, sex){ this.name=name

this.age=age this.sex=sex }

Và sau đó ta tạo ra hai người mới:

rank = new person(“Rank McKinnon”,33,”M”) ken = new person(“Ken John”,39,”M”)

Bây giờ bạn định nghĩa lại hàm xây dựng car như sau:

function car(make, model, year,owner ){ this.make = make

this.model = model this.year = year this.owner = owner }

Như vậy bạn có thể tạo đối tượng kiểu car mới:

car1 = new car(“Eagle”,”Talon TSi”,1993,rank) car2 = new car(“Nissan”,”300ZX”,1992,ken)

Như vậy, thay vì phải qua một xâu ký tự hay một giá trị số khi tạo đối tượng, ta chỉ cần đưa hai đối tượng đã được tạo ở câu lệnh trên vào dòng tham số của đối tượng mới tạo. Ta cũng có thể lấy được thuộc tính của đối tượng owner bằng câu lênh sau:

car2.owner.name

Chú ý rằng bạn cũng có thể tạo ra một thuộc tính mới cho đối tượng trước khi định nghĩa nó, ví dụ:

car1.color=”black”

Như vậy, thuộc tính color của đối tượng car1 được gán là “black”. Tuy nhiên, nó sẽ không gây tác động tới bất kỳ một đối tượng kiểu car nào khác. Nếu muốn thêm thuộc tính cho tất cả các đối tượng thì phải định nghĩa lại hàm xây dựng đối tượng.

Một phần của tài liệu Biến trong JavaScript (Trang 56 - 57)