Lấy fake path của file trong html input
TIL
720
HTML5
25
White

Hà Phạm viết ngày 23/06/2016

Lấy fake path của file trong html input

Ngữ cảnh: em cần làm một cái nút tải ảnh lên có preview.

GIải pháp đầu: Dùng FileReader đọc file ảnh thành base64 rồi ném vào url của phần tử img

let reader = new FileReader()

reader.onloadend = () => {
    imgElem.setAttribute('src', reader.result);
};

reader.readAsDataURL(input.files[0]);

Tuy nhiên tốn nhiều chữ, may mà có URL api cho phép lấy fake path (blob) của file ấy dễ hơn

let url = URL.createObjectURL(input.files[0]);
imgElem.setAttribute('src', url);

Mất có 2 dòng lại còn synchronize, trẻ con đọc cũng hiểu. Độ phủ trên trình duyệt là tương đương.

Note

Good practice là cần gọi revokeObjectURL khi đã xong việc với cái file ấy rồi, dù trình duyệt tự clear khi page unload, nhưng những người chuyên nghiệp không nên để lại quá nhiều dấu vết, phải không nhỉ.

mahpahh 09-05-2016

Bình luận


White
{{ comment.user.name }}
Bỏ hay Hay
{{comment.like_count}}
Male avatar
{{ comment_error }}
Hủy
   

Hiển thị thử

Chỉnh sửa

White

Hà Phạm

25 bài viết.
70 người follow
Kipalog
{{userFollowed ? 'Following' : 'Follow'}}
Cùng một tác giả
White
44 8
Xin chào, đây là lần đầu tiên mình post bài ở đây. Nhiều vấn đề mình cũng không rành lắm, có gì sai mọi người góp ý nhé. Xin cảm ơn :D Bài này gi...
Hà Phạm viết hơn 4 năm trước
44 8
White
36 8
Lâu không post gì muốn viết một bài dài dài về js cơ mà đau đầu quá viết mãi không xong, thôi post bài ngắn vậy :smiley: Lấy screen size ở đây tôi...
Hà Phạm viết gần 4 năm trước
36 8
White
32 3
Đây là một trong các concept mới đối tượng mới được đưa vào ECMAScript 6. Việc sử dụng chúng rất dễ nhưng để hiểu được thì (đối với tôi) cũng cần k...
Hà Phạm viết 4 năm trước
32 3
Bài viết liên quan
White
19 10
Lời nói đầu Tuần trước mình đã bắt tay vào làm thử app theo ý tưởng clone chương trình "Ai là triệu phú" trên TV, với các chức năng cơ bản, chỉ sử...
Andy Crush viết gần 4 năm trước
19 10
Male avatar
0 0
Phần 1: TỔNG QUAN 1. Lý do chọn đề tài Đồng hành cùng sự phát triển của khoa học công nghệ, lĩnh vực công nghệ thông tin cần được xây dựng phục ...
KohaJeseMen viết 19 ngày trước
0 0
{{like_count}}

kipalog

{{ comment_count }}

bình luận

{{liked ? "Đã kipalog" : "Kipalog"}}


White
{{userFollowed ? 'Following' : 'Follow'}}
25 bài viết.
70 người follow

 Đầu mục bài viết

Vẫn còn nữa! x

Kipalog vẫn còn rất nhiều bài viết hay và chủ đề thú vị chờ bạn khám phá!