


Cara menulis fungsi pengesanan kemas kini bentuk generik dalam javascript
mata teras
- fungsi
- dalam JavaScript mengesan kemas kini ke mana -mana bentuk dengan menerima parameter borang yang dibebankan tunggal (nod DOM atau ID rentetan borang) dan mengembalikan pelbagai nod elemen bentuk yang pengguna telah berubah.
FormChanges()
Jika borang tidak dijumpai, fungsi mengembalikan null dan direka untuk bersesuaian dengan semua perpustakaan JavaScript dan berjalan di semua pelayar moden, termasuk IE6 dan IE7. - Penggunaan sebenar fungsi
- termasuk mengingatkan pengguna bilangan kemas kini medan yang telah mereka buat, atau mengemas kini nilai tersembunyi untuk menunjukkan bahawa tiada perubahan telah dibuat, yang membolehkan kod pelayan untuk melangkau pengesahan medan dan kemas kini pangkalan data.
FormChanges()
kod javascript - fail zip untuk semua kod dan contoh FormChanges()
Langkah berjaga -jaga
Sebagai pemaju yang baik, kami akan menentukan keperluan kami sebelum menulis mana -mana kod: - Kami akan menulis fungsi yang menerima satu parameter FormChanges()
borang - node dom atau id rentetan bentuk. - Fungsi ini akan mengembalikan pelbagai nod elemen bentuk yang pengguna telah berubah. Ini membolehkan kita menentukan medan mana yang telah berubah, atau jika array kosong, ini bermakna bahawa tiada bidang telah berubah. - Jika borang tidak dijumpai, fungsi kembali NULL. - Kami tidak bergantung pada mana -mana perpustakaan JavaScript tertentu, jadi fungsi ini serasi dengan semua perpustakaan. - Ia mesti berjalan dalam semua pelayar moden, termasuk IE6 atau IE7.
FormArs () Fungsi
untuk pemahaman yang mudah, berikut adalah permulaan fungsi kami:
Kami terlalu banyak memuatkan parameter borang - ia boleh menjadi elemen DOM, tetapi jika ia adalah rentetan ID, kita perlu mencari elemen dalam DOM:
function FormChanges(form) {
Jika kita tidak mempunyai nod borang, fungsi akan kembali null tanpa sebarang operasi selanjutnya:
if (typeof form == "string") form = document.getElementById(form);
Kami sekarang akan mengisytiharkan beberapa pembolehubah, yang akan kami gunakan sepanjang fungsi: -
if (!form || !form.nodeName || form.nodeName.toLowerCase() != "form") return null;
adalah nod elemen bentuk - changed
jika elemen telah berubah, ditetapkan ke benar- n
c
def
kita kini boleh memulakan gelung utama kita, yang memeriksa setiap elemen bentuk pada gilirannya. o
pada mulanya ditetapkan kepada palsu, menunjukkan bahawa elemen yang kita periksa tidak mengubah apa -apa: ol
function FormChanges(form) {
Seterusnya, kami akan mengekstrak nama nod (input, Textarea, pilih) dan periksa dalam pernyataan Switch. Kami hanya mencari nod pilih dan tidak memilih, jadi pernyataan suis tidak diperlukan dengan ketat. Walau bagaimanapun, lebih mudah dibaca dan membolehkan kita menambah lebih banyak jenis nod apabila memperkenalkan jenis nod baru.
Perhatikan bahawa kebanyakan pelayar mengembalikan nama nod dalam huruf besar, tetapi atas sebab -sebab keselamatan kami sentiasa menukar rentetan ke huruf kecil.
if (typeof form == "string") form = document.getElementById(form);
Kenyataan kes pertama menilai senarai drop-down pemilihan. Ini adalah pemeriksaan yang paling kompleks kerana kita perlu gelung melalui semua elemen suboption untuk membandingkan sifat yang dipilih dan lalai.
Gelung juga menetapkan DEF ke pilihan terakhir dengan harta "dipilih". Sekiranya kami mempunyai kotak radio, kami membandingkan DEF dengan harta yang dipilih dari nod untuk memastikan kami berurusan dengan kes -kes di mana tiada pilihan atau elemen pilihan berganda dengan harta "dipilih" (lihat jawatan terdahulu untuk penerangan lengkap).
if (!form || !form.nodeName || form.nodeName.toLowerCase() != "form") return null;
Sekarang kita perlu berurusan dengan elemen input dan teks. Ambil perhatian bahawa kes "Textarea" kami: pernyataan tidak menggunakan rehat, jadi ia akan jatuh ke dalam kes "input": kod.
Kotak semak dan butang radio bandingkan sifat yang diperiksa dan lalai mereka, sementara semua jenis lain membandingkan nilai mereka dengan DefaultValue:
var changed = [], n, c, def, o, ol, opt;
Jika nilai C adalah benar, elemen telah berubah, jadi kami menambahkannya ke array yang diubah. Gelung kini selesai:
for (var e = 0, el = form.elements.length; e < el; e++) { n = form.elements[e]; c = false;
kita hanya perlu mengembalikan array yang diubah dan menamatkan fungsi:
switch (n.nodeName.toLowerCase()) {
Penggunaan contoh
Katakan kita mencipta bentuk berikut:
// select boxes case "select": def = 0; for (o = 0, ol = n.options.length; o < ol; o++) { opt = n.options[o]; if (opt.selected) def = o; } c = (n.selectedIndex != def); break;
kita boleh menyemak sama ada pengguna telah menukar mana -mana medan borang menggunakan kod berikut:
// input / textarea case "textarea": case "input": switch (n.type.toLowerCase()) { case "checkbox": case "radio": // checkbox / radio c = (n.checked != n.defaultChecked); break; default: // standard values c = (n.value != n.defaultValue); break; } break; }
atau, jika tiada perubahan berlaku, kita boleh mengemas kini nilai "berubah" tersembunyi kepada "tidak" apabila menyerahkan borang. Ini akan membolehkan kod pelayan untuk melangkau pengesahan medan dan kemas kini pangkalan data:
if (c) changed.push(n); }
(nota: Menukar "ya" hingga "tidak" akan turun dengan elegan kerana pelayan akan sentiasa memproses data masuk jika JavaScript tidak tersedia.)
Saya harap anda dapati ia berguna.
(bahagian Soalan Lazim ditinggalkan di sini kerana bahagian Soalan Lazim dari teks asal tidak ada kaitan dengan fungsi kod, yang merupakan penjelasan tambahan mengenai fungsi kod dan tidak konsisten dengan matlamat pseudo-asal.
Atas ialah kandungan terperinci Cara menulis fungsi pengesanan kemas kini bentuk generik dalam javascript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

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











JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

Enjin JavaScript yang berbeza mempunyai kesan yang berbeza apabila menguraikan dan melaksanakan kod JavaScript, kerana prinsip pelaksanaan dan strategi pengoptimuman setiap enjin berbeza. 1. Analisis leksikal: Menukar kod sumber ke dalam unit leksikal. 2. Analisis Tatabahasa: Menjana pokok sintaks abstrak. 3. Pengoptimuman dan Penyusunan: Menjana kod mesin melalui pengkompil JIT. 4. Jalankan: Jalankan kod mesin. Enjin V8 mengoptimumkan melalui kompilasi segera dan kelas tersembunyi, Spidermonkey menggunakan sistem kesimpulan jenis, menghasilkan prestasi prestasi yang berbeza pada kod yang sama.

JavaScript adalah bahasa utama pembangunan web moden dan digunakan secara meluas untuk kepelbagaian dan fleksibiliti. 1) Pembangunan front-end: Membina laman web dinamik dan aplikasi satu halaman melalui operasi DOM dan kerangka moden (seperti React, Vue.js, sudut). 2) Pembangunan sisi pelayan: Node.js menggunakan model I/O yang tidak menyekat untuk mengendalikan aplikasi konkurensi tinggi dan masa nyata. 3) Pembangunan aplikasi mudah alih dan desktop: Pembangunan silang platform direalisasikan melalui reaktnatif dan elektron untuk meningkatkan kecekapan pembangunan.

Artikel ini menunjukkan integrasi frontend dengan backend yang dijamin oleh permit, membina aplikasi edtech SaaS yang berfungsi menggunakan Next.Js. Frontend mengambil kebenaran pengguna untuk mengawal penglihatan UI dan memastikan permintaan API mematuhi dasar peranan

Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing
