Các kiểu dữ liệu trong JavaScript
Trong hai bài viết về biến và hằng trong JavaScript, mình có đề cập đến việc gán giá trị cho biến và hằng. Ở đó, mỗi giá trị đều có một kiểu dữ liệu nhất định. Vậy bạn có biết kiểu dữ liệu là gì và các kiểu dữ liệu trong JavaScript là gì không?
Sau đây mình sẽ cùng tìm hiểu và khám phá về những kiểu dữ liệu cơ bản trong JavaScript. Còn về chi tiết cụ thể của từng kiểu dữ liệu thì mình sẽ ra mắt ở những bài tiếp theo .
Bạn nhớ theo dõi phân mục JavaScript để không bỏ lỡ bài viết mới nhất .
Mục Chính
Kiểu dữ liệu là gì?
Kiểu dữ liệu là một cách phân loại dữ liệu cho trình biên dịch hoặc trình thông dịch hiểu về kiểu của dữ liệu đang sử dụng.
Bạn đang đọc: Các kiểu dữ liệu trong JavaScript
Đối với nhiều ngôn từ lập trình, khi khai báo một biến, bạn phải chỉ rõ biến đó thuộc kiểu dữ liệu gì. Nhưng so với JavaScript thì khác, một biến hoàn toàn có thể thuộc bất kể kiểu dữ liệu nào, ví dụ :
let x = 999; console.log(x); x = " Helloworld "; console.log(x);
Bạn thấy rằng, biến
x
ban đầu được gán giá trị kiểu số. Nhưng sau đó, mình gán lại giá trị kiểu chuỗi kí tự cho biếnx
và không có lỗi nào xảy ra.Đây vừa là ưu điểm, nhưng cũng là nhược điểm của JavaScript.
- Ưu điểm: kiểu dữ liệu linh động giúp việc lập trình trở nên linh hoạt hơn.
- Nhược điểm: khi chương trình trở nên phức tạp, số lượng dòng code nhiều lên, có thể bạn sẽ khó kiểm soát kiểu dữ liệu của biến, dẫn đến sai trong việc xử lý, tính toán.
Các kiểu dữ liệu trong JavaScript
JavaScript có 8 kiểu dữ liệu cơ bản, trong đó, có 7 kiểu dữ liệu nguyên thủy (boolean, null, undefined, number, BigInt, string, symbol) và 1 kiểu dữ liệu dạng tham chiếu (object).
Kiểu dữ liệu nguyên thủy: là kiểu dữ liệu mà giá trị không thể thay đổi được. Đây là kiểu dữ liệu ứng với “level thấp nhất” của ngôn ngữ lập trình.
Kiểu dữ liệu tham chiếu (object): là tập hợp của các thuộc tính (key) và giá trị (value). Mà số lượng các key có thể thay đổi, giá trị ứng với key cũng có thể thay đổi. Do đó, giá trị của kiểu dữ liệu tham chiếu có thể thay đổi được.
Kiểu dữ liệu boolean (kiểu logic)
Boolean là kiểu dữ liệu logic chỉ bao gồm hai giá trị là
true
(đúng, chính xác) vàfalse
(sai, không chính xác), ví dụ:let isWebLoaded = true; console.log(isWebLoaded); let isProgramRunning = false; console.log(isProgramRunning);
Kiểu dữ liệu null
Kiểu dữ liệu null là một kiểu dữ liệu đặc biệt, chỉ bao gồm một giá trị là
null
, ví dụ:let language = null; console.log(language);
Trong ví dụ trên, biến
language
được hiểu là không biết giá trị hoặc không có giá trị.Kiểu dữ liệu undefined
Cũng tương tự như null, undefined là một kiểu dữ liệu đặc biệt trong JavaScript, chỉ bao gồm một giá trị
undefined
, ví dụ:let language = undefined; console.log(language);
Kiểu dữ liệu undefined có nghĩa là giá trị chưa được gán.
📝 Khác nhau cơ bản giữa undefined và null:
Kiểu dữ liệu null là kiểu dữ liệu được gán cho biến, thường được hiểu là không biết (không có).
Trong khi đó, kiểu dữ liệu undefined là giá trị mặc định của biến sau khi khai báo mà không gán giá trị cho biến.
Ví dụ khai báo biến mà không gán giá trị :
let language; console.log(language);
Trường hợp biến đã có giá trị rồi, bạn vẫn có thể chủ động gán lại giá trị undefined cho biến. Tuy nhiên, điều này là không nên. Vì như vậy là không đúng ý nghĩa của kiểu dữ liệu undefined.
let language = " JavaScript "; console.log(language); language = undefined; console.log(language); language = null; console.log(language);
Kiểu dữ liệu number
Kiểu dữ liệu number là kiểu dữ liệu dạng số ( tựa như trong toán học ). Number trong JavaScript không có cú pháp gì đặc biệt quan trọng. Bạn chỉ cần viết số ra .
JavaScript có hai loại số là: số nguyên và số thực.
let n1 = 66; let n2 = -66; let n3 = 3.14; let n4 = -3.14; let n5 = 2 e3; let n6 = 2 e - 3; let n7 = 0 xff; let n8 = 067; let n9 = 0 b11;
Ngoài những loại số trên, JavaScript còn có 3 số đặc biệt là: Infinity, -Infinity và NaN.
- Infinity: là số dương vô cùng. Đây là giá trị đặc biệt và nó lớn hơn bất kỳ số nào khác. Bạn có thể sử dụng giá trị này trực tiếp hoặc thu được nó bằng cách lấy lấy số dương bất kỳ chia cho 0 (toán tử chia trong JavaScript là
/
).console.log(Infinity); console.log(1 / 0);
- -Infinity: là số âm vô cùng. Đây cũng là giá trị đặc biệt và nó nhỏ hơn bất kỳ số nào khác. Bạn có thể sử dụng giá trị này trực tiếp hoặc thu được nó bằng cách lấy lấy số âm bất kỳ chia cho 0.
console.log(-Infinity); console.log(-1 / 0);
- NaN: là viết tắt của Not a Number, được sử dụng để đại diện cho những trường hợp tính toán sai hoặc kết quả của một phép tính không xác định.
console.log(0 / 0
)
; console.log(" JavaScript " / 2); console.log(Infinity - Infinity);Nhờ những số đặc biệt quan trọng này mà việc thống kê giám sát trong JavaScript ” luôn bảo đảm an toàn ” .
Vì chương trình sẽ không bao giờ bị crash do lỗi chia cho 0 hay giá trị không phải số. Điều mà bạn có thể gặp phải ở nhiều ngôn ngữ khác như C/C++, Java,…
Kiểu dữ liệu BigInt
Trong JavaScript, kiểu dữ liệu number không thể biểu diễn một số nguyên lớn hơn
(253-1)
(bằng 9007199254740991) và nhỏ hơn-(253-1)
.Với hầu hết các trường hợp, việc sử dụng kiểu dữ liệu number là quá đủ. Nhưng đôi khi, bạn vẫn cần biểu diễn và tính toán với những số nguyên cực kỳ lớn. Do đó, kiểu dữ liệu BigInt ra đời nhằm giải quyết vấn đề này.
Để biểu diễn số nguyên với kiểu BigInt, bạn chỉ cần thêm chữ cái
n
ở phía sau, ví dụ:const reallyBigNumber = 12345678987654321012345678987654321 n; console.log(reallyBigNumber);
Kiểu dữ liệu string
String là kiểu dữ liệu dùng để màn biểu diễn chữ, văn bản, đoạn văn bản, …
Có ba cách để trình diễn string trong JavaScript :
- Dùng dấu nháy đơn (
'
)- Dùng dấu nháy kép (
"
)- Dùng dấu “backtick” (
`
)Ví dụ :
const msg1 = 'Đây là string dùng dấu nháy đơn'; const msg2 = "Đây là string dùng dấu nháy kép"; const msg3 = `Đây là string dùng dấu backtick`;
Dấu nháy đơn và dấu nháy kép là trọn vẹn giống nhau .
Riêng với dấu “backtick”, bạn có thể sử dụng biến, hằng hoặc thậm chí viết một biểu thức trong đó, với cú pháp
${…}
, ví dụ:let name = " Lam "; console.log(
`My name is
USD {name}
`); const language = " JavaScript "; console.log(`You are learning
USD {language}
`); console.log(`1 + 2 =
USD {1 + 2}
`);String trong JavaScript có thể chỉ gồm 1 kí tự
"a"
, nhiều kí tự"abc"
hoặc không kí tự nào""
(empty string).Kiểu dữ liệu symbol
Symbol là một kiểu dữ liệu nguyên thủy dùng để tạo ra các giá trị duy nhất (unique value) và bất biến (immutable). Symbol thường được dùng làm key cho kiểu dữ liệu object sau đây.
Mình đã viết một bài chi tiết cụ thể về Symbol. Bạn hoàn toàn có thể tìm hiểu và khám phá về Symbol trong JavaScript để hiểu nhiều hơn về kiểu dữ liệu này .
Kiểu dữ liệu object
Object là kiểu dữ liệu tham chiếu. Có thể hiểu object là một tập hợp gồm các cặp key – value (khóa – giá trị).
Trong đó, kiểu dữ liệu của key có thể là string hoặc symbol. Và value ứng với key có thể là bất kỳ kiểu dữ liệu nào.
Mình sẽ tìm hiểu sâu hơn về object trong bài viết JavaScript Object – last but not least.
Cách xác định kiểu dữ liệu của biến
Như mình đã nói ở trên, một biến trong JavaScript có thể thuộc bất kỳ kiểu dữ liệu nào. Để xác định kiểu dữ liệu hiện tại của một biến, JavaScript cung cấp cho bạn
typeof
, với hai loại cú pháp:
- Dạng toán tử
typeof x
.- Dạng hàm
typeof(x)
.Kết quả trả về sẽ là một
string
ứng với tên của kiểu dữ liệu. Ví dụ về toán tửtypeof
với các kiểu dữ liệu trong JS:let x; console.log(typeof x); x = true; console.log(typeof x); x = 1; console.log(typeof x); x = 1234567891234567890123456789125345362 n; console.log(typeof x); x = " hello "; console.log(typeof x);
x = Symbol(" id ");
console.log(typeof x);
x = { n: 1 };
console.log(typeof x);
x = null;
console.log(typeof x);
Cần nói thêm về ba trường hợp ( 1 ), ( 2 ), ( 3 ) .
(1): Cách khởi tạo symbol sẽ trình bày chi tiết ở bài tìm hiểu về Symbol trong JavaScript.
(2): Cách tạo object sẽ trình bày chi tiết ở bài JavaScript Object – last but not least.
(3): Đây có thể coi là một lỗi của
typeof
được tạo ra khi JavaScript mới xuất hiện. Nhưng vì tính tương thích ngược, nên đặc điểm này củatypeof
vẫn được giữ đến bây giờ.Tổng kết
Sau đây là tóm tắt những kỹ năng và kiến thức cơ bản về những kiểu dữ liệu trong JavaScript :
JavaScript có 8 kiểu dữ liệu cơ bản, trong đó, có 7 kiểu dữ liệu nguyên thủy (boolean, null, undefined, number, BigInt, string, symbol) và 1 kiểu dữ liệu dạng tham chiếu (object).
- Kiểu dữ liệu
boolean
: bao gồm hai giá trịtrue
vàfalse
dùng để biểu diễn đúng và sai. - Kiểu dữ liệu
null
: chỉ gồm một giá trịnull
, dùng để biểu thị trạng thái không biết giá trị. - Kiểu dữ liệu
undefined
: chỉ gồm một giá trịundefined
, dùng để biểu thị trạng thái chưa gán giá trị. - Kiểu dữ liệu
number
: dùng để biểu diễn số nguyên hoặc số thực. Trong đó, số nguyên giới hạn trong đoạn±(253-1
. - Kiểu dữ liệu
BigInt
: dùng để biểu diễn số nguyên lớn, có độ dài tùy ý. Để biểu diễn số thuộc kiểuBigInt
, bạn chỉ cần thêm chữ cáin
ở cuối. - Kiểu dữ liệu
string
: dùng để biểu diễn kí tự, chuỗi ký tự,… bằng cách sử dụng dấu nháy đơn ('
), nháy kép ("
) hoặc dấu “backtick” (`
). Mỗi string có thể chứa một kí tự, nhiều kí tự hoặc không chứa kí tự nào (empty string). - Kiểu dữ liệu
symbol
: dùng để tạo ra những giá trị duy nhất, thường dùng làm “key” choobject
. - Kiểu dữ liệu
object
: là tập hợp của các cập key-value.
Để kiểm tra kiểu dữ liệu của một biến, bạn có thể sử dụng typeof
.
- Có hai dạng: dạng toán tử
typeof x
hoặc ở dạng hàmtypeof(x)
. - Kết quả trả về là một
string
ứng với tên của kiểu dữ liệu. typeof null
trả vềobject
. Đây là một lỗi sơ khai của JavaScript. Thực chất,null
không phải làobject
.
Source: https://thomaygiat.com
Category : Kỹ Thuật Số
Chuyển vùng quốc tế MobiFone và 4 điều cần biết – MobifoneGo
Muốn chuyển vùng quốc tế đối với thuê bao MobiFone thì có những cách nào? Đừng lo lắng, bài viết này của MobiFoneGo sẽ giúp…
Cách copy dữ liệu từ ổ cứng này sang ổ cứng khác
Bạn đang vướng mắc không biết làm thế nào để hoàn toàn có thể copy dữ liệu từ ổ cứng này sang ổ cứng khác…
Hướng dẫn xử lý dữ liệu từ máy chấm công bằng Excel
Hướng dẫn xử lý dữ liệu từ máy chấm công bằng Excel Xử lý dữ liệu từ máy chấm công là việc làm vô cùng…
Cách nhanh nhất để chuyển đổi từ Android sang iPhone 11 | https://thomaygiat.com
Bạn đã mua cho mình một chiếc iPhone 11 mới lạ vừa ra mắt, hoặc có thể bạn đã vung tiền và có một chiếc…
Giải pháp bảo mật thông tin trong các hệ cơ sở dữ liệu phổ biến hiện nay
Hiện nay, với sự phát triển mạnh mẽ của công nghệ 4.0 trong đó có internet và các thiết bị công nghệ số. Với các…
4 điều bạn cần lưu ý khi sao lưu dữ liệu trên máy tính
08/10/2020những chú ý khi tiến hành sao lưu dữ liệu trên máy tính trong bài viết dưới đây của máy tính An Phát để bạn…