Cara Menambah Kaunter Pelawat Boleh Diklik pada Tapak Web Anda
Jan 05, 2025 pm 02:24 PMSaya sedang memikirkan sesuatu yang menyeronokkan dan interaktif untuk ditambahkan pada portfolio saya dan kaunter boleh klik yang boleh digunakan oleh pelawat untuk meninggalkan sedikit mesej "Saya berada di sini" dirasakan seperti idea yang bagus. Ia mudah, menarik dan cara yang bagus untuk menjadikan tapak web anda berasa lebih peribadi. Jika ini kelihatan seperti sesuatu yang anda ingin buat, panduan ini akan membimbing anda melaluinya langkah demi langkah.
Kami akan meneruskan pembinaan kaunter paparan berfungsi sepenuhnya langkah demi langkah. Anda tidak perlu menjadi pembangun berpengalaman untuk mengikutinya. Mari selami!
1. HTML: Membina Struktur
Pertama, kami akan menyediakan struktur untuk kaunter paparan. Walaupun anda boleh menggunakan mana-mana ikon atau gaya butang yang anda suka, saya akan menggunakan ikon mata untuk tutorial ini. Inilah kod HTML:
<div> <h2> 2. The CSS: Styling the Counter </h2> <p>Let’s add some simple styling to make the counter look clean and centered. Here’s the CSS:<br> </p> <pre class="brush:php;toolbar:false">.eye-counter { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); } .eye-button { background: none; border: none; cursor: pointer; display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem; border-radius: 20px; background-color: rgba(255, 255, 255, 0.1); color: #333; transition: transform 0.3s ease, background-color 0.3s ease; } .eye-button:hover { transform: scale(1.05); background-color: rgba(255, 255, 255, 0.2); } .eye-icon { fill: currentColor; } .view-count { font-size: 1rem; font-weight: bold; }
CSS ini memusatkan kaunter pada halaman dan menambahkan beberapa kesan tuding untuk butang.
3. Menghidupkannya dengan Javascript
Sekarang untuk acara utama, membuat kaunter berfungsi.
Berikut ialah JavaScript, dipecahkan kepada fungsi untuk menjadikannya mudah:
// Run code after the page has loaded document.addEventListener('DOMContentLoaded', async () => { const eyeButton = document.querySelector('.eye-button'); const viewCount = document.querySelector('.view-count'); const BIN_URL = 'https://api.jsonbin.io/v3/b/YOUR_BIN_ID'; // Replace with your bin URL const API_KEY = 'YOUR_API_KEY'; // Replace with your API key // Function to get the visitor's IP address async function getVisitorIP() { try { const response = await fetch('https://api.ipify.org?format=json'); const data = await response.json(); return data.ip; } catch (error) { console.error('Error fetching IP:', error); return null; } } // Function to fetch data from JSONBin async function fetchBinData() { const response = await fetch(BIN_URL, { headers: { 'X-Master-Key': API_KEY } }); const result = await response.json(); return result.record; } // Function to update data in JSONBin async function updateBinData(data) { await fetch(BIN_URL, { method: 'PUT', headers: { 'Content-Type': 'application/json', 'X-Master-Key': API_KEY }, body: JSON.stringify(data) }); } // Main logic const visitorIP = await getVisitorIP(); if (!visitorIP) { eyeButton.classList.add('disabled'); return; } const binData = await fetchBinData(); viewCount.textContent = binData.totalClicks; if (binData.clickedIPs.includes(visitorIP)) { eyeButton.classList.add('disabled'); } eyeButton.addEventListener('click', async () => { if (!eyeButton.classList.contains('disabled')) { binData.totalClicks += 1; binData.clickedIPs.push(visitorIP); await updateBinData(binData); viewCount.textContent = binData.totalClicks; eyeButton.classList.add('disabled'); } }); });
Memecahkannya:
- Dapatkan IP Pelawat: Ambil alamat IP pelawat menggunakan ipify.
- Ambil Data Bin: Mendapatkan semula jumlah klik semasa dan senarai IP daripada JSONBin.
- Kemas kini Data Bin: Mengemas kini kiraan klik dan senarai IP dalam JSONBin.
- Halang Berbilang Klik: Menyemak sama ada pelawat telah mengklik dan melumpuhkan butang jika ya.
4. Menyediakan JSONBin
Jika anda tidak pernah menggunakan JSONBin sebelum ini, jangan risau! Ikuti langkah ini:
- Pergi ke JSONBin.io dan daftar untuk mendapatkan akaun percuma.
- Buat tong baharu dengan data awal berikut:
{ "totalClicks": 0, "clickedIPs": [] }
- Selepas menyimpan tong, salin ID Bin daripada halaman butiran tong.
- Pergi ke tetapan akaun anda untuk menjana Kunci API.
- Ganti YOUR_BIN_ID dan YOUR_API_KEY dalam kod JavaScript dengan Bin ID dan Kunci API anda yang sebenar.
Itu sahaja! Anda telah membina kaunter paparan yang menyeronokkan dan interaktif. Ini cara mudah untuk menarik perhatian pelawat dan menambahkan sentuhan personaliti pada tapak anda.
Sila lawati portfolio saya untuk melihatnya beraksi.
Atas ialah kandungan terperinci Cara Menambah Kaunter Pelawat Boleh Diklik pada Tapak Web Anda. 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)

Topik panas

JavaScriptisidealForWebDevelopment, whersjavasuitslarge-scaleapplicationsandandroiddevelopment.1) javascriptexcelsincreatinginteractivewebexperiencesandfull-stackdevelopmentwithnode.js.2)

Dalam JavaScript, memilih satu-satunya komen (//) atau ulasan multi-line (//) bergantung kepada keperluan dan keperluan projek komen: 1. Gunakan komen satu baris untuk tafsiran cepat dan sebaris; 2. Gunakan komen berbilang baris untuk dokumentasi terperinci; 3. Mengekalkan konsistensi gaya komen; 4. Elakkan daripada annotasi; 5. Pastikan komen dikemas kini secara serentak dengan kod. Memilih gaya anotasi yang betul dapat membantu meningkatkan kebolehbacaan dan pemeliharaan kod anda.

Ya, JavaScriptcommentsareneraryAnderyShouldbeusedefectively.1) theguedevelopersthroughcodelogicandIntent, 2) arevitalincomplexprojects, and3) couldenhanceclaritywithoutclutterthecode.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza, masing -masing sesuai untuk senario aplikasi yang berbeza. Java digunakan untuk pembangunan aplikasi perusahaan dan mudah alih yang besar, sementara JavaScript digunakan terutamanya untuk pembangunan laman web.

Commentsarecrucialinjavascriptformaintainingclarityandfosteringcollaboration.1) theyhelpindebugging, onboarding, andunderstandingcodeevolution.2) menggunakan-linecommentsforquickexplanationsandmulti-linecommentsfordetaileddescriptions.3)

Javascripthasseveralprimitivedatatypes: nombor, rentetan, boolean, undefined, null, simbol, andbigint, dan non-primitivetypesliikeobjectandarray.UnderstheseiscialfritingFritingefisien, bug-freecode: 1) numberusesa64-fitformat, pemimpin-fitformat, pemimpin-fitformat

JavaScriptispreferredforwebdevelopment, whersjavaisbetterforlarge-scalebackendsystemsandandroidapps.1) javascriptexcelsinceleatinginteractiveWebexperienceswithitsdynamicnatureanddommanipulation.2) javaoffersstrongyblectionandobjection
