cari
Rumahhujung hadapan webSoal Jawab bahagian hadapanCara membuat kalendar menggunakan javascript

Apabila aplikasi web menjadi semakin popular, ramai pembangun perlu melaksanakan kalendar dalam tapak web atau aplikasi mereka untuk membolehkan pengguna memilih tarikh. Mudah untuk membuat kalendar yang ringkas tetapi berkuasa menggunakan JavaScript. Dalam artikel ini, kami akan membincangkan langkah asas untuk melaksanakan kalendar menggunakan JavaScript dan menyediakan kod sampel.

  1. Skeleton HTML

Pertama, kami memerlukan rangka kerja HTML untuk mengehoskan kalendar kami. Kami perlu mencipta elemen <div> dan menetapkan ID unik supaya kami boleh memanipulasinya melalui JavaScript. Kita perlu memasukkan dua kotak input dan satu butang dalam elemen <code><div> ini, satu kotak input untuk memaparkan tarikh yang dipilih dan satu lagi untuk menerima input tarikh baharu. <ol start="2"><li>Dapatkan tarikh semasa </li></ol> <p>Dalam JavaScript, kami mendapat tarikh semasa dengan menggunakan objek Tarikh. Kita boleh mendapatkan tarikh bulan semasa menggunakan kaedah getDate() dan mendapatkan tahun semasa menggunakan kaedah getFullYear(). </p> <ol start="3"><li>Membina kalendar </li></ol> <p>Seterusnya, kita perlu membina kalendar. Kita boleh mencipta kalendar ringkas menggunakan elemen jadual. Kita boleh menggunakan gelung for untuk menjana sel jadual yang mengandungi tarikh. Satu perkara yang perlu kita ambil perhatian ialah hari pertama setiap bulan tidak semestinya hari Ahad, jadi kita perlu menggunakan nilai indeks sel pertama untuk menentukan tarikh ia harus bermula. </p> <ol start="4"><li>Mengendalikan pemilihan tarikh</li></ol> <p>Untuk membenarkan pengguna memilih tarikh, kami boleh menggunakan JavaScript untuk mendengar acara kotak input untuk mengemas kini kalendar apabila baharu tarikh dipilih. Kita boleh menggunakan objek Tarikh untuk membandingkan dua tarikh dan mendapatkan bilangan hari antara tarikh tersebut. Jika tarikh yang dipilih lebih besar daripada tarikh semasa maka kita boleh menatal kalendar ke hadapan jika tidak, kita boleh menatal kalendar ke belakang. </p> <ol start="5"><li>Tambah kefungsian butang </li></ol> <p>Akhir sekali, kita perlu menambah kefungsian pada butang lungsur untuk menunjukkan atau menyembunyikan kalendar apabila pengguna mengklik butang. Kami boleh menyembunyikan atau menunjukkan kalendar dengan menggunakan gaya CSS dan kemudian menambahkan pendengar acara pada butang untuk menogol keterlihatannya. </p> <p>Beberapa ciri tambahan termasuk: </p> <ul> <li>Tambah kelas untuk menyerlahkan tarikh yang dipilih pada masa ini serta tarikh yang dilegar </li> <li>Bezakan antara hujung minggu dan hari bekerja</li> <li>Selesaikan isu merentas tahun/bulan</li> </ul> <p>Contoh kod:</p> <p>HTML:</p> <pre class="brush:php;toolbar:false">&lt;div&gt;   &lt;input&gt;   &lt;input&gt;   &lt;button&gt;V&lt;/button&gt;   &lt;table&gt;&lt;/table&gt; &lt;/div&gt;</pre> <p>CSS:</p> <pre class="brush:php;toolbar:false">#calendar {   position: relative; } #calendar input[type=&quot;text&quot;] {   padding: 5px;   border: 1px solid #ccc;   font-size: 16px; } #calendar table {   display: none;   position: absolute;   top: 30px;   left: 0;   border-collapse: collapse; } #calendar td {   padding: 5px;   text-align: center;   cursor: pointer; } #calendar .currentDay {   background-color: #B6D9FA; } #calendar .hoverDay {   background-color: #EAEAEA; } #calendar .weekend {   color: red; }</pre> <p>JavaScript :</p> <pre class="brush:php;toolbar:false">var currentDate = new Date(); var selectedDate = document.getElementById('selectedDate'); var newDate = document.getElementById('newDate'); var calBtn = document.getElementById('calBtn'); var calendarTable = document.getElementById('calendarTable'); // Update selected date whenever the date input is changed selectedDate.addEventListener('change', function() {   currentDate = new Date(selectedDate.value);   updateCalendar(); }); // Show/hide calendar when button is clicked calBtn.addEventListener('click', function() {   if (calendarTable.style.display === 'none') {     calendarTable.style.display = 'table';   } else {     calendarTable.style.display = 'none';   } }); // Add event listeners for hovering over calendar dates calendarTable.addEventListener('mouseover', function(e) {   if (e.target.nodeName === 'TD' &amp;&amp; e.target.innerHTML !== '') {     e.target.classList.add('hoverDay');   } }); calendarTable.addEventListener('mouseout', function(e) {   if (e.target.nodeName === 'TD' &amp;&amp; e.target.innerHTML !== '') {     e.target.classList.remove('hoverDay');   } }); // Generate calendar function updateCalendar() {   var currentMonth = currentDate.getMonth();   var currentYear = currentDate.getFullYear();   var daysInMonth = new Date(currentYear, currentMonth + 1, 0).getDate();   var firstDayIndex = new Date(currentYear, currentMonth, 1).getDay();   var lastDayIndex = new Date(currentYear, currentMonth, daysInMonth).getDay();   var prevMonthDays = new Date(currentYear, currentMonth, 0).getDate();   var calendarHtml = '';      // Add table headings   calendarHtml += '&lt;tr&gt;&lt;th&gt;' + getMonthName(currentMonth) + ' ' + currentYear + '&lt;/th&gt;&lt;/tr&gt;'   calendarHtml += '&lt;tr&gt; &lt;th&gt;Sun&lt;/th&gt; &lt;th&gt;Mon&lt;/th&gt; &lt;th&gt;Tue&lt;/th&gt; &lt;th&gt;Wed&lt;/th&gt; &lt;th&gt;Thu&lt;/th&gt; &lt;th&gt;Fri&lt;/th&gt; &lt;th&gt;Sat&lt;/th&gt; &lt;/tr&gt;';      // Add days of previous month before the first day of current month   var prevMonthDaysToAdd = firstDayIndex === 0 ? 6 : firstDayIndex - 1;   var prevMonthStartDay = prevMonthDays - prevMonthDaysToAdd + 1;   for (var i = 0; i ' + prevMonthStartDay + '';     prevMonthStartDay++;   }      // Add days of current month   for (var i = 1; i ' + i + '';     } else if (isWeekend(new Date(currentYear, currentMonth, i).getDay())) {       calendarHtml += '&lt;td&gt;' + i + '&lt;/td&gt;';     } else {       calendarHtml += '&lt;td&gt;' + i + '&lt;/td&gt;';     }     if (new Date(currentYear, currentMonth, i).getDay() === 6) {       calendarHtml += '&lt;tr&gt;';     }   }      // Add days of next month after the last day of current month   var nextMonthDaysToAdd = lastDayIndex === 0 ? 0 : 7 - lastDayIndex;   for (var i = 1; i ' + i + '';     if (lastDayIndex === 6 &amp;&amp; i === nextMonthDaysToAdd) {       break;     }   }      // Append the calendar to the HTML   calendarTable.innerHTML = calendarHtml; } // Get the name of the month from its numerical value function getMonthName(month) {   var monthNames = ['January', 'February', 'March', 'April', 'May', 'June',     'July', 'August', 'September', 'October', 'November', 'December'   ];   return monthNames[month]; } // Check if a day is a weekend day function isWeekend(day) {   return day === 0 || day === 6; } updateCalendar();&lt;/tr&gt;</pre> </div>

Atas ialah kandungan terperinci Cara membuat kalendar menggunakan javascript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Rangka Kerja Backend: PerbandinganRangka Kerja Backend: PerbandinganApr 13, 2025 am 12:06 AM

React adalah rangka kerja front-end untuk membina antara muka pengguna; Rangka kerja back-end digunakan untuk membina aplikasi sisi pelayan. React menyediakan kemas kini UI yang komponen dan cekap, dan Rangka Kerja Backend menyediakan penyelesaian perkhidmatan backend lengkap. Apabila memilih timbunan teknologi, keperluan projek, kemahiran pasukan, dan skalabiliti harus dipertimbangkan.

HTML dan React: Hubungan antara markup dan komponenHTML dan React: Hubungan antara markup dan komponenApr 12, 2025 am 12:03 AM

Hubungan antara HTML dan React adalah teras pembangunan front-end, dan mereka bersama-sama membina antara muka pengguna aplikasi web moden. 1) HTML mentakrifkan struktur kandungan dan semantik, dan React membina antara muka dinamik melalui komponenisasi. 2) Komponen React Gunakan sintaks JSX untuk membenamkan HTML untuk mencapai rendering pintar. 3) Kitaran Hayat Komponen Menguruskan Rendering HTML dan Kemas kini secara dinamik mengikut keadaan dan atribut. 4) Gunakan komponen untuk mengoptimumkan struktur HTML dan meningkatkan keupayaan. 5) Pengoptimuman prestasi termasuk mengelakkan penyampaian yang tidak perlu, menggunakan atribut utama, dan menjaga tanggungjawab tunggal komponen.

React and the Frontend: Membina Pengalaman InteraktifReact and the Frontend: Membina Pengalaman InteraktifApr 11, 2025 am 12:02 AM

React adalah alat pilihan untuk membina pengalaman front-end interaktif. 1) React memudahkan pembangunan UI melalui komponen dan DOM maya. 2) Komponen dibahagikan kepada komponen fungsi dan komponen kelas. Komponen fungsi adalah lebih mudah dan komponen kelas menyediakan lebih banyak kaedah kitaran hayat. 3) Prinsip kerja React bergantung kepada algoritma DOM dan perdamaian maya untuk meningkatkan prestasi. 4) Pengurusan negeri menggunakan useState atau ini. Kaedah kitaran hayat seperti ComponentDidMount digunakan untuk logik tertentu. 5) Penggunaan asas termasuk membuat komponen dan pengurusan negeri, dan penggunaan lanjutan melibatkan cangkuk tersuai dan pengoptimuman prestasi. 6) Kesalahan biasa termasuk kemas kini status yang tidak betul dan isu prestasi, kemahiran debugging termasuk menggunakan reactdevtools dan sangat baik

React and the Frontend Stack: Alat dan TeknologiReact and the Frontend Stack: Alat dan TeknologiApr 10, 2025 am 09:34 AM

React adalah perpustakaan JavaScript untuk membina antara muka pengguna, dengan komponen terasnya dan pengurusan negeri. 1) Memudahkan pembangunan UI melalui komponen dan pengurusan negeri. 2) Prinsip kerja termasuk perdamaian dan rendering, dan pengoptimuman dapat dilaksanakan melalui React.Memo dan Usememo. 3) Penggunaan asas adalah untuk membuat dan membuat komponen, dan penggunaan lanjutan termasuk menggunakan cangkuk dan konteksapi. 4) Kesalahan biasa seperti kemas kini status yang tidak betul, anda boleh menggunakan ReactDevTools untuk debug. 5) Pengoptimuman prestasi termasuk menggunakan react.memo, senarai virtualisasi dan codesplitting, dan menyimpan kod yang boleh dibaca dan dikekalkan adalah amalan terbaik.

Peranan React dalam HTML: Meningkatkan Pengalaman PenggunaPeranan React dalam HTML: Meningkatkan Pengalaman PenggunaApr 09, 2025 am 12:11 AM

React menggabungkan JSX dan HTML untuk meningkatkan pengalaman pengguna. 1) JSX membenamkan HTML untuk menjadikan pembangunan lebih intuitif. 2) Mekanisme DOM maya mengoptimumkan prestasi dan mengurangkan operasi DOM. 3) UI pengurusan berasaskan komponen untuk meningkatkan kebolehkerjaan. 4) Pengurusan negeri dan pemprosesan acara meningkatkan interaktiviti.

Komponen React: Membuat unsur -unsur yang boleh diguna semula di HTMLKomponen React: Membuat unsur -unsur yang boleh diguna semula di HTMLApr 08, 2025 pm 05:53 PM

Komponen React boleh ditakrifkan oleh fungsi atau kelas, merangkumi logik UI dan menerima data input melalui prop. 1) Tentukan komponen: Gunakan fungsi atau kelas untuk mengembalikan elemen bertindak balas. 2) Rendering Component: React Call Render Kaedah atau Melaksanakan Komponen Fungsi. 3) Komponen multiplexing: Lulus data melalui prop untuk membina UI yang kompleks. Pendekatan kitaran hayat komponen membolehkan logik dilaksanakan pada peringkat yang berbeza, meningkatkan kecekapan pembangunan dan pemeliharaan kod.

Tujuan mod yang ketatTujuan mod yang ketatApr 02, 2025 pm 05:51 PM

React Mode Strict adalah alat pembangunan yang menyoroti isu -isu yang berpotensi dalam aplikasi React dengan mengaktifkan cek tambahan dan amaran. Ia membantu mengenal pasti kod warisan, hayat yang tidak selamat, dan kesan sampingan, menggalakkan amalan reaksi moden.

Reaksi penggunaan serpihanReaksi penggunaan serpihanApr 02, 2025 pm 05:50 PM

Serpihan bertindak balas membolehkan kumpulan kanak -kanak tanpa nod dom tambahan, meningkatkan struktur, prestasi, dan kebolehaksesan. Mereka menyokong kekunci untuk rendering senarai yang cekap.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),