peri hoki perihoki clarustologistics rimashaop.com angelpaintingtools.co.in vrjanaenergies.com gates of olympus perihoki jadi mesin uang paling gacor trik main baccarat perihoki ala pro bikin pemula jadi jutawan pantang pulang sebelum jackpot main dadu sicbo perihoki pgsoft mahjong ways 2 muncul scatter merah tiap spin perihoki cara menciptakan akun perihokigacor mahjong wins 3 jackpot kembar mahjong wins 3 abc1131 cara menang stabil rtp mahjong ways abc1131 bu nurlina menang 197 juta mahjong ways 2 mahasiswa cuan 421 juta karena pola mahjong pemilik warung menang 128 juta mahjong wins 3 strategi bravy erika mahjong abc1131 terungkap pemuda jambi taklukkan mahjong wins 3 penjual jamu menang besar mahjong wins 5 pemuda kampung raup 180 juta mahjong ways kisah inspiratif petani mahjong ways keberhasilan mahasiswa menang 92 juta mahjong ways modal warung kopi bang ojak sukses mahjong ways tanpa modal maxwin mahjong wins 3 strategi bocoran mahjong ways spin kombinasi cara bermain mahjong untuk meraih keberuntungan keajaiban mahjong kasir indomaret sukses beli tanah meraup keuntungan maksimal di mahjong wins rahasia kemenangan mahjong ways spin slow
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 282
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: session_set_cookie_params(): Cannot change session cookie parameters when headers already sent
Filename: Session/Session.php
Line Number: 294
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 304
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 314
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 315
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 316
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 317
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: Session/Session.php
Line Number: 375
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: ini_set(): Headers already sent. You cannot change the session module's ini settings at this time
Filename: drivers/Session_files_driver.php
Line Number: 108
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: session_set_save_handler(): Cannot change save handler when headers already sent
Filename: Session/Session.php
Line Number: 110
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
A PHP Error was encountered
Severity: Warning
Message: session_start(): Cannot start session when headers already sent
Filename: Session/Session.php
Line Number: 143
Backtrace:
File: /home/blogchuabenh/domains/freetuts.net/public_html/site/controllers/Main_controller.php
Line: 10
Function: __construct
File: /home/blogchuabenh/domains/freetuts.net/public_html/sources/index.php
Line: 299
Function: require_once
File: /home/blogchuabenh/domains/freetuts.net/public_html/index.php
Line: 26
Function: require_once
Tạo một component FileUpload trong ReactJS - Freetuts
REACTJS EXAMPLE
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
Tạo một component FileUpload trong ReactJS
Trong bài này, mình sẽ tạo một component FileUpload
chứa một biểu mẫu cho phép người dùng tải lên một file, sử dụng Controlled Components
để quản lý trạng thái và hiển thị thông tin và file đã chọn trong console.
File Upload trong ReactJS
Mình sẽ bắt đầu bằng việc tạo một ứng dụng React mới và thêm component FileUpload
vào đó.
Bước 1: Tạo một ứng dụng React mới
npx create-react-app react-file-upload
cd react-file-upload
Bước 2: Tạo component FileUpload
Trong thư mục src, tạo một file mới có tên là FileUpload.js
. File này sẽ chứa component FileUpload
.
FileUpload.js
import React, { useState } from 'react';
import './FileUpload.css';
const FileUpload = () => {
const [selectedFile, setSelectedFile] = useState(null);
const handleFileChange = (e) => {
const file = e.target.files[0];
setSelectedFile(file);
};
const handleUpload = () => {
if (selectedFile) {
console.log('Thông tin tệp đã chọn:', selectedFile);
// Thêm logic xử lý file tải lên ở đây (ví dụ: gửi đến API, lưu vào state, ...)
setSelectedFile(null); // Đặt lại trạng thái tệp đã chọn sau khi tải lên
}
};
return (
<div className="file-upload-container">
<input type="file" onChange={handleFileChange} />
<button onClick={handleUpload}>Upload</button>
</div>
);
};
export default FileUpload;
Bước 3: Tạo file CSS cho FileUpload
Tạo một file CSS mới có tên là FileUpload.css
trong thư mục src để trang trí giao diện của FileUpload
.
FileUpload.css
.file-upload-container {
max-width: 400px;
margin: auto;
padding: 20px;
border: 1px solid #ccc;
border-radius: 8px;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
input {
display: block;
margin-bottom: 16px;
}
button {
background-color: #4caf50;
color: white;
padding: 10px 15px;
border: none;
border-radius: 4px;
cursor: pointer;
}
button:hover {
background-color: #45a049;
}
Bước 4: Sử dụng component FileUpload trong App
Sửa nội dung file src/App.js để sử dụng component FileUpload
.
App.js
import React from 'react';
import FileUpload from './components/FileUpload';
import './App.css';
function App() {
return (
<div className="App">
<h1>React File Upload Exercise</h1>
<FileUpload />
</div>
);
}
export default App;
Bước 5: Chạy ứng dụng React
Quay lại terminal và chạy lệnh sau để khởi động ứng dụng React:
Mở trình duyệt và truy cập http://localhost:3000 để xem ứng dụng của bạn. Bạn sẽ thấy một biểu mẫu cho phép tải lên file với ô chọn file và nút "Upload". Khi bạn chọn file và nhấn nút, thông tin về file đã chọn sẽ hiển thị trong console.
Kết bài
Với bài tập "File Upload" này, mình đã sử dụng Controlled Components để quản lý trạng thái và xử lý sự kiện khi người dùng tải lên file. CSS đã được kết hợp để tạo ra giao diện thân thiện và dễ sử dụng. Hãy tiếp tục tìm hiểu và thực hành để làm quen với các tính năng khác của ReactJS và phát triển kỹ năng lập trình của bạn!
Bài giải
-------------------- ######## --------------------
Câu hỏi thường gặp liên quan:
Cùng chuyên mục: