- vừa được xem lúc

[HTML] Bài 8 - Các Kiểu Input Khác

0 0 8

Người đăng: Thịnh Trần

Theo Viblo Asia

Trong bài viết trước, chúng ta đã nói về <form> và các kiểu <input> cơ bản. Bên cạnh đó, HTML còn hỗ trợ nhiều kiểu input khác giúp chúng ta tạo ra những biểu mẫu dễ dàng và linh động hơn, phù hợp với nhiều loại câu hỏi truy vấn thông tin từ người dùng. Hãy cùng nói về các kiểu input này.

Các kiểu input phổ biến khác

HTML có tất cả 3 nhóm input phổ biến bao gồm:

  1. Các trường nhập văn bản:
    • Text-field - trường nhập văn bản 1 dòng
    • Text-area - trường nhập văn bản nhiều dòng
  2. Các danh sách lựa chọn:
    • Radio-button - nhóm các nút lựa chọn hình tròn, hỗ trợ 1 lựa chọn
    • Check-box - nhóm các ô lựa chọn hình vuông, hỗ trợ nhiều lựa chọn
    • Dropdown-list - danh sách lựa chọn dạng cuộn có thể đóng mở, hỗ trợ 1 lựa chọn
  3. Các loại input khác:
    • Nút chọn tệp để tải lên từ máy tính của người dùng
    • Chọn ngày tháng trong lịch hiển thị ở dạng bảng
    • Chọn màu sắc trong bảng màu
    • v.v....

1. Text-field & Text-area

Chúng ta đã gặp text-field trong ví dụ của bài viết trước rồi. Còn về text-area thì thực sự không có gì nhiều khác biệt cả. Chỉ đơn giản là một cái text-field được mở rộng xuống nhiều dòng. Để tạo một text-area thì bạn sử dụng thẻ textarea thay vì <input>.

textarea.html

<form method="post"> Người nhận:<br> <input type="text" name="recipient"><br> Tin nhắn:<br> <textarea name="message"></textarea><br> <button type="submit">Gửi</button> <button type="button">Hủy</button>
</form>

2. Radio-button & Check-box & Dropdown-list

Các kiểu input phổ biến tiếp theo là radio-button, check-box, và dropdown-list, giúp chúng ta cung cấp các đáp án lựa chọn cho người dùng.

Radio-button & Check-box

Radio-button và check-box được tạo bằng cách sử dụng các thẻ <input> và có phong cách hiển thị khá giống nhau. Trong khi radio-button chỉ hỗ trợ 1 lựa chọn duy nhất thì check-box hỗ trợ người dùng chọn nhiều hơn 1 đáp án.

choices.html

<form> <b>Radio-buttons:</b><br> Nam <input type="radio" name="gender" value="male" checked> | Nữ <input type="radio" name="gender" value="female"> | Khác <input type="radio" name="gender" value="other"><br> <br> <b>Check-boxes:</b><br> Đỏ <input type="checkbox" name="favcolor" value="red"> | Xanh lá <input type="checkbox" name="favcolor" value="green" checked> | Xanh Dương <input type="checkbox" name="favcolor" value="blue"><br> <br> <button type="submit">Gửi</button>
</form>

Bạn có thể nhận thấy một vài thuộc tính mới được sử dụng ở đây: valuechecked.

Lý do là vì các input này không hỗ trợ người dùng nhập đáp án bằng việc gõ chữ, do đó chúng ta cần phải chỉ định các giá trị mặc định cho mỗi lựa chọn bằng thuộc tính value. Thuộc tính này cũng có thể được sử dụng để thiết lập nội dung mặc định cho text-field và text-area.

Thuộc tính checked được sử dụng để thiết lập một lựa chọn được đánh dấu mặc định.

Dropdown-list

Dropdown-list được sử dụng trong trường hợp có rất nhiều lựa chọn mà chúng ta cần cung cấp cho người dùng. Ví dụ điển hình thường thấy là danh sách quốc tịch, hay danh sách địa danh thành phố, quận, phường, v.v...

dropdown.html

<form> Xuất sứ: <select name="hometown"> <option value="earth">Trái Đất</option> <option value="mars">Sao Hỏa</option> <option value="moon">Mặt Trăng</option> </select> <br> <button type="submit">Xác nhận :D</button>
</form>

3. File-browser & Các kiểu input khác

Đây là cách để tạo ra một nút nhấn mà khi người dùng nhấp chuột vào thì trình duyệt web sẽ mở ra một cửa sổ duyệt thư mục và chọn tệp đăng tải. Ví dụ thường thấy là các nút đăng tải hình ảnh hay audio, video của các mạng xã hội.

file.html

<form> <input type="file" name="photo"><br> <button type="submit">Đăng tải ảnh</button>
</form>

Bên cạnh các kiểu input phổ biến mà chúng ta đã liệt kê ở phía trên, HTML còn hỗ trợ rất nhiều kiểu input khác nữa rất tuyệt vời và hỗ trợ bởi các trình duyệt web được cập nhật thường xuyên với phiên bản mới. Đây là liên kết tham khảo về danh sách đầy đủ các kiểu input của HTML 5 phiên bản mới nhất hiện tại: Danh sách các kiểu input.

Thẻ <label>

Đây là một tiện ích được thiết kế để sử dụng kèm với các radio-button và check-box. Thẻ tiện ích này sẽ giúp chúng ta cung cấp trải nghiệm sử dụng tốt hơn tới người dùng thiết bị di động. Với thẻ label, chúng ta có thể tạo ra một vùng có thể nhận cick chuột và gắn với các ô lựa chọn nhỏ. Bằng cách này thì người dùng sẽ có thể chạm vào phần chữ mô tả ở bên cạnh ô lựa chọn để đánh dấu vào ô đó thay vì phải cố gắng chạm vài lần để trúng được 1 ô lựa chọn nhỏ.

Cách đơn giản nhất để gắn một label vào một lựa chọn là bạn chỉ cần đặt luôn phần tử input bên trong thẻ <label>.

label.html

<!-- Các ô check-box ở đây có thể được chọn bằng cách click hoặc chạm vào tên màu.
-->
<form> <b>Màu sắc:</b><br> <label> Đỏ <input type="checkbox" name="favcolor" value="red"> | </label> <label> Xanh lá <input type="checkbox" name="favcolor" value="green"> | </label> <label> Xanh dương <input type="checkbox" name="favcolor" value="blue"> </label> <br> <button type="submit">Gửi</button>
</form>

Một label cũng có thể được gắn với một input bằng cách sử dụng thuộc tính for. Trong trường hợp này, chúng ta sẽ cần thêm id cho input.

label.html

<form> <label for="accept">Click ở đây</label><br> <input id="accept" type="checkbox" name="confirm" value="accept"> Tôi đã đọc và đồng ý với các điều khoản.<br> <button type="submit">Xác nhận</button>
</form>

Bài viết về các kiểu input khác trong HTML của chúng ta tới đây là kết thúc. Đây cũng là bài viết cuối cùng trong series HTML cho người mới học mà mình thực hiện. Để tìm hiểu kiến thức mở rộng và học chi tiết hơn về HTML, bạn có thể sử dụng các nguồn sau:

  • Mozilla Developer Network - Cộng đồng nhà phát triển của Mozilla vận hành, đây là công ty chủ của dự án trình duyệt web miễn phí Firefox. Đánh giá chung về các nội dung kiến thức được đăng tải bởi MDN

Bình luận

Bài viết tương tự

- vừa được xem lúc

Một số quy tắc và name class phổ biến cho Front-end Dev

Trong CSS, các thủ tục setting đóng vai trò to lớn, nhưng bên cạnh đó, cách đặt tên theo các từ đơn sao cho phù hợp cũng quan trọng không kém . Đặt tên rất khó, nhưng cũng rất quan trọng .

0 0 93

- vừa được xem lúc

2021, chúng ta cần tối ưu hóa việc tải hình ảnh trên web như nào?

Rất chào các bạn,. Như các bạn đã biết, trong kỉ nguyên công nghệ, song song với sự sinh ra dày đặc của các trang web mới cũng là sự biến mất của những trang web "lạc hậu" hay hoạt động kém hiệu quả.

0 0 57

- vừa được xem lúc

Tài nguyên nghiên cứu sâu Html

1. Articles and standards. . HTML 5.

0 0 198

- vừa được xem lúc

Tìm hiểu về Event.preventDefault(), Event.stopPropagation() và Event.stopImmediatePropagation()

Chúng ta thương thấy 3 method này và có thể dẫn dến bối rối và nhầm lẫn giữa chúng:. . Event.preventDefault().

0 0 52

- vừa được xem lúc

Vanilla JS Project: Tính tuổi

1. Yêu cầu.

0 0 75

- vừa được xem lúc

Thủ thuật nhỏ để căn chỉnh image với object-fit

Chào các bạn,. Có lẽ trong hành trình code của các bạn thì không ít lần gặp vấn đề méo ảnh do fix cứng cả width, height của ảnh nhỉ? Hoặc kể cả khi bạn set value cho 1 thuộc tính weigth hoặc height còn thuộc tính còn lại để auto thì nhiều lúc ảnh cũng không được hiển thị toàn vẹn cho lắm.

0 0 49