


Menguasai Carta Semula: Panduan Komprehensif untuk Mencipta Carta dalam ReactJS
Jika anda bekerja dengan ReactJS dan ingin menghidupkan data dengan carta, Recharts menawarkan cara terbaik untuk mencipta visualisasi yang menakjubkan dengan mudah. Dalam panduan ini, kami akan menggunakan Recharts dan Fakestore API untuk mengambil dan memaparkan data produk dalam carta bar dan carta pai.
Anda juga boleh menyemak repositori github dan demo langsung. Mari mulakan!
?️ Persediaan: Bermula dengan Vite
Mula-mula, mari buat apl React baharu menggunakan Vite.
- Pasang Vite dengan arahan berikut:
npm create vite@latest
-
Ikuti gesaan:
- Nama projek: carta
- Kerangka: Bertindak balas
- Varian: JavaScript
Alih ke folder projek anda, pasang kebergantungan dan mulakan pelayan:
cd charts npm install npm run dev
Dengan projek anda berjalan, mari buat dua komponen: satu untuk Carta Bar Harga Produk dan satu lagi untuk Carta Pai Kategori Produk.
? Langkah 1: Mencipta Carta Bar Harga Produk (ProductChart.jsx)
Dalam komponen ini, kami akan mengambil data produk daripada API dan menggambarkannya dengan carta bar.
Kod
Buat fail dalam src/components/ProductChart.jsx dengan kod berikut:
// src/components/ProductChart.jsx import React from 'react'; import axios from 'axios'; import { useState, useEffect } from 'react'; import { BarChart, Bar, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts'; export default function ProductChart() { const [products, setProducts] = useState([]); const fetchData = async () => { try { const response = await axios.get('https://fakestoreapi.com/products'); setProducts(response.data); } catch (err) { console.log(err); } }; useEffect(() => { fetchData(); }, []); // Prepare data for chart const chartData = products.map(item => ({ name: item.id, price: item.price, })); return ( <> <div className='product'> <h3 className='product-heading'>PRODUCT PRICE BAR CHART</h3> <ResponsiveContainer width='95%' height={450}> <BarChart data={chartData} margin={{ top: 5, right: 30, left: 20, bottom: 20, }} > <CartesianGrid strokeDasharray="3 3" /> <XAxis dataKey="name" label={{ value: "Product ID", position: "bottom", offset: -5 }} /> <YAxis label={{ value: "Price", angle: -90, position: "insideLeft", offset: -10 }} /> <Tooltip /> <Bar dataKey="price" fill="#eca1ac" /> </BarChart> </ResponsiveContainer> </div> </> ); }
Penjelasan
- ResponsiveContainer: Menjadikan carta responsif dengan menetapkan lebarnya kepada 95% dan ketinggian kepada 450px.
- BarChart: Komponen utama yang memaparkan carta bar.
- CartesianGrid: Menambah grid latar belakang untuk kebolehbacaan.
- XAxis & YAxis: Sediakan label untuk ID produk dan harga.
- Petua alat: Menunjukkan data apabila melayang di atas bar.
- Bar: Memaparkan bar, dengan setiap bar mewakili harga produk.
? Langkah 2: Mencipta Carta Pai Kategori Produk (CategoryChart.jsx)
Dalam komponen ini, kami akan mengambil data produk, mengira produk dalam setiap kategori dan menggambarkannya menggunakan carta pai.
Kod
Buat fail dalam src/components/CategoryChart.jsx dengan kod berikut:
npm create vite@latest
Penjelasan
- Kaedah Pengiraan kategori: Mengira bilangan produk dalam setiap kategori dan memformatkan hasil untuk paparan dalam carta pai.
- Carta Pai & Pai: Komponen utama yang menghasilkan carta pai.
- Sel: Menambah warna pada setiap kepingan pai, ditakrifkan oleh tatasusunan COLORS.
- cx, cy dan outerradius: Letakkan dan saiz carta pai dalam bekas.
?️ Langkah 3: Memaparkan Komponen dalam App.js
Untuk melihat carta anda dalam tindakan, anda perlu memaparkan komponen ini dalam App.js.
Kod
Kemas kini src/App.js seperti berikut:
cd charts npm install npm run dev
Dengan adanya ini, anda seharusnya melihat kedua-dua carta bar dan carta pai pada skrin anda!
? Kesimpulan
Tahniah! Anda telah berjaya menggunakan Recharts untuk membuat visualisasi data dinamik dan responsif dalam apl React. Kami telah membincangkan:
- Menyediakan projek React dengan Vite
- Mengambil dan memproses data daripada API Fakestore
- Mencipta carta bar dan pai menggunakan Recharts
Carta semula menjadikan membina visualisasi interaktif mudah dan boleh disesuaikan. Eksperimen dengan jenis carta dan sumber data lain untuk mencipta visualisasi yang lebih menarik!
Atas ialah kandungan terperinci Menguasai Carta Semula: Panduan Komprehensif untuk Mencipta Carta dalam ReactJS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Memulakan projek dan buat pakej.json; 2. Buat skrip kemasukan index.js dengan shebang; 3. Daftar perintah melalui medan bin dalam pakej.json; 4. Gunakan Yargs dan perpustakaan lain untuk menghuraikan parameter baris arahan; 5. Gunakan ujian tempatan NPMLink; 6. Tambah bantuan, versi dan pilihan untuk meningkatkan pengalaman; 7. Secara pilihan menerbitkan melalui NPMPublish; 8. Secara pilihan mencapai penyelesaian automatik dengan YARGS; Akhirnya buat alat CLI praktikal melalui struktur yang munasabah dan reka bentuk pengalaman pengguna, tugas automasi lengkap atau mengedarkan widget, dan berakhir dengan ayat lengkap.

Gunakan document.createelement () untuk membuat elemen baru; 2. Sesuaikan elemen melalui textContent, classlist, setAttribute dan kaedah lain; 3. Gunakan kaedah tambahan () atau lebih fleksibel () untuk menambah elemen ke DOM; 4. Secara pilihan menggunakan InsertBefore (), sebelum () dan kaedah lain untuk mengawal kedudukan penyisipan; Proses lengkap adalah untuk membuat → Sesuaikan → Tambah, dan anda boleh mengemas kini kandungan halaman secara dinamik.

Jenis Keadaan Lanjutan TypeScript Melaksanakan penghakiman logik antara jenis melalui Textendsu? X: Y Sintaks. Keupayaan terasnya ditunjukkan dalam jenis keadaan yang diedarkan, kesimpulan jenis kesimpulan dan pembinaan alat jenis kompleks. 1. Jenis bersyarat diedarkan dalam parameter jenis kosong dan secara automatik boleh memecah jenis bersama, seperti toarray untuk mendapatkan rentetan [] | number []. 2. Menggunakan Pengagihan untuk Membina Alat Penapisan dan Pengekstrakan: Tidak termasuk Kecualikan Jenis Melalui Textendsu? Tidak pernah: T, Ekstrak Ekstrak Persamaan melalui Textendsu? 3

Microfrontendssolvescalingchallengesinlargeteamsbyenablingindependentdevelopmentanddeployment.1) chooseanInintegrationstration: useModulefederationInwebPack5formruntimeLoadingandtrueindectivence, Build-timeIntegrationForseMlesetups, Oriframes/Web

varisfunction-scoped, canbereassigned, omredwithundefined, andattachedtotheglobalwindowobject; 2.Letandconstareblock-scoped, withletallowingreassignmentandconstnotallowingit, everconstobjectscanhaveMutabeTerSties;
