Nhận thời gian JavaScript
Dấu thời gian UNIX được định nghĩa là số giây kể từ ngày 1 tháng 1 năm 1970 UTC. Trong JavaScript, để lấy dấu thời gian hiện tại, bạn có thể sử dụng Show Điều quan trọng cần lưu ý là
Lớp Trước khi bạn điTôi biết, một bản tin khác - nhưng hãy nghe tôi nói. Hầu hết các bản tin JavaScript đều tệ. Lần cuối cùng bạn thực sự mong muốn có được một cái là khi nào? Chúng tôi gọi nó là Byte, nhưng những người khác gọi nó là bản tin yêu thích của họ tham gia byte Được gửi tới 151.908 nhà phát triển vào mỗi thứ Hai và thứ Năm Sdu @sduduzo_g Đây là bản tin đầu tiên mà tôi mở danh sách phát nhạc và tối đa hóa cửa sổ trình duyệt của mình chỉ để yên tâm đọc nó. Kudos để @uidotdev cho nội dung hàng tuần tuyệt vời Brandon Bayer @flybayer Bản tin Bytes là một tác phẩm nghệ thuật. Đó là bản tin dành cho nhà phát triển duy nhất mà tôi đã đăng ký. Bằng cách nào đó, họ lấy những thứ hơi nhàm chán và truyền vào đó một lượng hài vừa phải để khiến bạn cười khúc khích John Hawley @johnhawly Bytes là bản tin yêu thích của tôi kể từ khi thành lập. Đó là điều yêu thích của tôi mà tôi mong đợi vào thứ Hai. Tuyệt vời với một tách cà phê nóng màu xanh lá cây Garrett @garrettgreen Tôi đăng ký RẤT NHIỀU bản tin dành cho nhà phát triển (đặc biệt là JS/TS/Node) và Byte của @uidotdev luôn là một sự thay đổi thú vị, được hoan nghênh đối với hầu hết (hài hước, vui vẻ, v.v.) nhưng vẫn toàn diện/hữu ích Muhammad @mhashim6_ Thực sự là bản tin duy nhất mà tôi chờ đợi mỗi tuần Grayson Hicks @graysonhicks Bytes là bản tin dành cho nhà phát triển mà tôi mong chờ nhất mỗi tuần. Cân bằng tuyệt vời giữa nội dung và ngữ cảnh. Cảm ơn @uidotdev Mitchell Wright @mitchellbwright Tôi biết tôi đã nói điều đó trước đây, nhưng @tylermcginnis không bỏ lỡ email Bytes. Nếu bạn là nhà phát triển, bạn thực sự cần phải đăng ký Ali Spittel @aspittel Tôi có thể nói rằng tôi cười khúc khích mỗi khi nhận được email @uidotdev mỗi tuần không? Chris Finn @thefinnomenon Mọi lập trình viên JavaScript nên đăng ký nhận bản tin từ @uidotdev. Họ không chỉ quản lý để đưa tin ngắn gọn về những tin tức nóng hổi trong thế giới JavaScript trong tuần mà họ còn quản lý để thêm sự hài hước mới mẻ vào tất cả Hãy gặp một đối tượng tích hợp mới. Ngày. Nó lưu trữ ngày, giờ và cung cấp các phương thức quản lý ngày/giờ Chẳng hạn, chúng ta có thể sử dụng nó để lưu trữ thời gian tạo/sửa đổi, để đo thời gian hoặc chỉ để in ra ngày hiện tại Để tạo một đối tượng 3 mới, hãy gọi 4 với một trong các đối số sau 4Không có đối số – tạo một đối tượng 3 cho ngày và giờ hiện tại
7Tạo một đối tượng 3 với thời gian bằng số mili giây (1/1000 giây) được truyền sau ngày 1 tháng 1 năm 1970 UTC+0________số 8_______ Một số nguyên đại diện cho số mili giây đã trôi qua kể từ đầu năm 1970 được gọi là dấu thời gian Đó là một đại diện số nhẹ của một ngày. Chúng tôi luôn có thể tạo một ngày từ dấu thời gian bằng cách sử dụng 9 và chuyển đổi đối tượng 3 hiện có thành dấu thời gian bằng cách sử dụng phương thức 1 (xem bên dưới)Ngày trước 01. 01. 1970 có dấu thời gian âm, e. g
2Nếu có một đối số duy nhất và đó là một chuỗi thì nó sẽ được phân tích cú pháp tự động. Thuật toán giống như cách sử dụng của 3, chúng tôi sẽ đề cập sau
4Tạo ngày với các thành phần đã cho theo múi giờ địa phương. Chỉ có hai đối số đầu tiên là bắt buộc
Ví dụ
Độ chính xác tối đa là 1 ms (1/1000 giây)
Có các phương thức để truy cập năm, tháng, v.v. từ đối tượng 3getFullYear()Lấy năm (4 chữ số)getMonth()Lấy tháng, từ 0 đến 11. getDate() Lấy ngày trong tháng, từ 1 đến 31, tên của phương thức có vẻ hơi lạ. getHours(), getMinutes(), getSeconds(), getMilliseconds() Nhận các thành phần thời gian tương ứngKhông phải Nhiều công cụ JavaScript triển khai một phương pháp không chuẩn 7. Phương pháp này không được chấp nhận. Đôi khi nó trả về năm có 2 chữ số. Xin vui lòng không bao giờ sử dụng nó. Có 8 trong nămNgoài ra, chúng ta có thể nhận được một ngày trong tuần getDay()Lấy ngày trong tuần, từ 0 (Chủ Nhật) đến 2 (Thứ Bảy). Ngày đầu tiên luôn là Chủ nhật, ở một số quốc gia thì không, nhưng không thể thay đổiTất cả các phương pháp trên trả về các thành phần liên quan đến múi giờ địa phương Ngoài ra còn có các đối tác UTC của chúng, trả về ngày, tháng, năm, v.v. cho múi giờ UTC+0. getUTCFullYear(), getUTCMonth(), getUTCDay(). Chỉ cần chèn 3 ngay sau 4Nếu múi giờ địa phương của bạn bị thay đổi so với UTC, thì mã bên dưới sẽ hiển thị các giờ khác nhau
Bên cạnh các phương thức đã cho, có hai phương thức đặc biệt không có biến thể UTC dành thời gian()Trả về dấu thời gian cho ngày – một số mili giây được truyền từ ngày 1 tháng 1 năm 1970 UTC+0 getTimezoneOffset()Trả về chênh lệch giữa UTC và múi giờ địa phương, tính bằng phút
Các phương pháp sau đây cho phép thiết lập các thành phần ngày/giờ
Chẳng hạn, mỗi người trong số họ ngoại trừ 3 đều có biến thể UTC. 4Như chúng ta có thể thấy, một số phương thức có thể thiết lập nhiều thành phần cùng một lúc, ví dụ như 5. Các thành phần không được đề cập không được sửa đổiVí dụ
Tự động sửa lỗi là một tính năng rất tiện dụng của các đối tượng 3. Chúng tôi có thể đặt các giá trị ngoài phạm vi và nó sẽ tự động điều chỉnhVí dụ
Các thành phần ngày nằm ngoài phạm vi được phân phối tự động Giả sử chúng ta cần tăng ngày “28 Feb 2016” thêm 2 ngày. Có thể là “2 tháng 3” hoặc “1 tháng 3” trong trường hợp năm nhuận. Chúng ta không cần phải suy nghĩ về nó. Chỉ cần thêm 2 ngày. Đối tượng 3 sẽ làm phần còn lại 0Tính năng đó thường được sử dụng để lấy ngày sau một khoảng thời gian nhất định. Chẳng hạn, hãy lấy ngày cho “70 giây sau bây giờ” 1Chúng tôi cũng có thể đặt giá trị bằng 0 hoặc thậm chí âm. Ví dụ 2Khi một đối tượng 3 được chuyển đổi thành số, nó sẽ trở thành dấu thời gian giống như 1 3Tác dụng phụ quan trọng. ngày có thể được trừ đi, kết quả là sự khác biệt của chúng trong ms Điều đó có thể được sử dụng để đo thời gian 4Nếu chúng ta chỉ muốn đo thời gian, chúng ta không cần đối tượng 3Có một phương thức đặc biệt 1 trả về dấu thời gian hiện tạiVề mặt ngữ nghĩa, nó tương đương với 2, nhưng nó không tạo đối tượng trung gian 3. Vì vậy, nó nhanh hơn và không gây áp lực cho việc thu gom rácNó được sử dụng chủ yếu để thuận tiện hoặc khi hiệu suất quan trọng, chẳng hạn như trong các trò chơi bằng JavaScript hoặc các ứng dụng chuyên dụng khác Vì vậy, điều này có lẽ là tốt hơn 5Nếu chúng ta muốn có một điểm chuẩn đáng tin cậy về chức năng ngốn CPU, chúng ta nên cẩn thận Chẳng hạn, hãy đo hai hàm tính toán sự khác biệt giữa hai ngày. cái nào nhanh hơn? Các phép đo hiệu suất như vậy thường được gọi là "điểm chuẩn" 6Hai cái này thực hiện chính xác cùng một việc, nhưng một trong số chúng sử dụng 1 rõ ràng để lấy ngày tính bằng ms và cái còn lại dựa vào phép biến đổi ngày thành số. Kết quả của họ luôn giống nhauVì vậy, cái nào nhanh hơn? Ý tưởng đầu tiên có thể là chạy chúng nhiều lần liên tiếp và đo chênh lệch thời gian. Đối với trường hợp của chúng tôi, các chức năng rất đơn giản, vì vậy chúng tôi phải thực hiện ít nhất 100000 lần Hãy đo lường 7Ồ. Sử dụng 5 nhanh hơn rất nhiều. Đó là bởi vì không có chuyển đổi loại, các công cụ sẽ tối ưu hóa dễ dàng hơn nhiềuĐược rồi, chúng tôi có một cái gì đó. Nhưng đó vẫn chưa phải là một điểm chuẩn tốt Hãy tưởng tượng rằng tại thời điểm chạy 6, CPU đang làm một việc gì đó song song và nó đang lấy tài nguyên. Và đến thời điểm chạy 7 công việc đó đã hoàn thànhMột kịch bản khá thực tế cho một hệ điều hành đa tiến trình hiện đại Do đó, điểm chuẩn đầu tiên sẽ có ít tài nguyên CPU hơn điểm chuẩn thứ hai. Điều đó có thể dẫn đến kết quả sai Để đo điểm chuẩn đáng tin cậy hơn, toàn bộ gói điểm chuẩn phải được chạy lại nhiều lần Ví dụ, như thế này 8Các công cụ JavaScript hiện đại bắt đầu chỉ áp dụng tối ưu hóa nâng cao cho “mã nóng” thực thi nhiều lần (không cần tối ưu hóa những thứ hiếm khi được thực thi). Vì vậy, trong ví dụ trên, lần thực hiện đầu tiên không được tối ưu hóa tốt. Chúng tôi có thể muốn thêm một lần khởi động 9Hãy cẩn thận khi thực hiện microbenchmarking Các công cụ JavaScript hiện đại thực hiện nhiều tối ưu hóa. Họ có thể điều chỉnh kết quả của “các bài kiểm tra nhân tạo” so với “việc sử dụng thông thường”, đặc biệt khi chúng tôi đánh giá một thứ gì đó rất nhỏ, chẳng hạn như cách thức hoạt động của một nhà điều hành hoặc một chức năng tích hợp sẵn. Vì vậy, nếu bạn thực sự muốn hiểu hiệu suất, thì hãy nghiên cứu cách thức hoạt động của công cụ JavaScript. Và sau đó, bạn có thể sẽ không cần microbenchmark nữa Gói bài viết tuyệt vời về V8 có thể được tìm thấy tại https. //mrale. ph Phương pháp Ngày. parse(str) có thể đọc một ngày từ một chuỗi Định dạng chuỗi phải là. 8, ở đâu
Cũng có thể có các biến thể ngắn hơn, chẳng hạn như 9 hoặc 6 hoặc thậm chí là 7Cuộc gọi đến ____52_______8 phân tích cú pháp chuỗi ở định dạng đã cho và trả về dấu thời gian (số mili giây từ ngày 1 tháng 1 năm 1970 UTC+0). Nếu định dạng không hợp lệ, trả về 9Ví dụ 0Chúng ta có thể ngay lập tức tạo một đối tượng 0 từ dấu thời gian 1
Lưu ý rằng không giống như nhiều hệ thống khác, dấu thời gian trong JavaScript tính bằng mili giây, không phải giây Đôi khi chúng ta cần các phép đo thời gian chính xác hơn. Bản thân JavaScript không có cách đo thời gian tính bằng micro giây (1 phần triệu giây), nhưng hầu hết các môi trường đều cung cấp nó. Chẳng hạn, trình duyệt có hiệu suất. now() cung cấp số mili giây kể từ khi bắt đầu tải trang với độ chính xác micro giây (3 chữ số sau dấu chấm) 2Nút. js có mô-đun 6 và các cách khác. Về mặt kỹ thuật, hầu hết mọi thiết bị và môi trường đều cho phép đạt được độ chính xác cao hơn, chỉ là không có trong 3
Làm cách nào để có được thời gian hiện tại trong JavaScript?Trong JavaScript, chúng ta có thể dễ dàng lấy ngày hoặc giờ hiện tại bằng cách sử dụng đối tượng Date() mới . Theo mặc định, nó sử dụng múi giờ của trình duyệt của chúng tôi và hiển thị ngày ở dạng chuỗi văn bản đầy đủ, chẳng hạn như "Fri Jun 17 2022 10. 54. 59 GMT+0100 (Giờ mùa hè của Anh)" chứa ngày, giờ và múi giờ hiện tại.
Làm cách nào để in thời gian trong JavaScript?Sử dụng tập lệnh sau để lấy thời gian hiện tại bằng JavaScript trong “H. i. định dạng s. var hôm nay = Ngày mới(); . . getHours() – Cung cấp giờ hiện tại trong khoảng 0-23 getMinutes() – Cung cấp số phút hiện tại trong khoảng 0-59 getSeconds() – Cung cấp giây hiện tại trong khoảng 0-59 Làm cách nào để có thời gian 12 giờ trong JavaScript?var now = new Date(); . var hours = now. getHours() % 12. 12; // 12h thay vì 24h, với 12 thay vì 0.
Date() getTime() mới là gì?Phương thức JavaScript Date getTime() được được sử dụng để trả về số mili giây kể từ ngày 1 tháng 1 năm 1970 . khi một đối tượng Ngày mới được tạo, nó sẽ lưu trữ dữ liệu ngày và giờ khi nó được tạo. Khi phương thức getTime() được gọi trên đối tượng ngày này, nó trả về số mili giây kể từ ngày 1 tháng 1 năm 1970 (Kỷ nguyên Unix). |