Rumah hujung hadapan web tutorial js pengesahan ajax jquery gagal dan borang diserahkan untuk menyelesaikan masalah_jquery

pengesahan ajax jquery gagal dan borang diserahkan untuk menyelesaikan masalah_jquery

May 16, 2016 pm 04:27 PM
ajax jquery

validationEngine mengurangkan banyak kerja untuk kami dalam pengesahan borang bahagian hadapan Dalam kebanyakan kes, kami menggunakan validationEngine untuk mengesahkan borang dalam beberapa cara:

1 Gunakan penyerahan borang biasa Dalam kes ini, borang tidak akan diserahkan sekiranya Enjin pengesahan gagal dalam pengesahan.

2 Gunakan ajax untuk menyerahkan borang, tetapi jangan gunakan pengesahan ajax.

Kaedah ini juga agak mudah, cuma semak sama ada pengesahan diluluskan sebelum kami menggunakan permintaan ajax, contohnya:

Salin kod Kod adalah seperti berikut:

//kembali apabila pengesahan gagal
If(!$("form#ajaxForm").validationEngine("validate")) return ; $.ajax({
Taip: "POST",
URL: $("#ajaxForm").attr("action"),
Data: $("#ajaxForm").serialize(),
Jenis Data: "html",
Kejayaan: fungsi(data){
                                                    });


3 Gunakan borang biasa untuk menghantar, tetapi menggunakan pengesahan ajax ini agak mengelirukan Internet perlu menukar kod sumber , berikut ialah tangkapan skrin:

. Kaedah ini sesuai untuk keadaan semasa Kaedah pengubahsuaian ini sendiri tidak disyorkan dan mungkin memberi kesan kepada tempat lain Salah satu perkara yang saya dapati adalah apabila situasi berikut berlaku

Salin kod Kod adalah seperti berikut: fungsi beforeCall(borang, pilihan){
If(window.console){
console.log("Selepas pengesahan penyerahan borang diluluskan, panggilan balik sebelum penyerahan Ajax"); };
Kembalikan benar; };
//
fungsi ajaxValidationCallback(status,borang,json,options){
If(window.console){
console.log(status);
};
Jika(status === benar){
alert("borang itu sah!"); }  
};
jQuery(dokumen).sedia(fungsi(){
jQuery("#formID").Enjin pengesahan({
ajaxFormValidation: true, //Sama ada hendak menggunakan Ajax untuk menyerahkan borang
ajaxFormValidationMethod: 'post', // Tetapkan cara untuk menghantar data apabila Ajax menyerahkan
onAjaxFormComplete: ajaxValidationCallback, //Penyerahan borang, selepas pengesahan Ajax selesai
onBeforeAjaxFormValidation: beforeCall //Selepas pengesahan penyerahan borang diluluskan, panggilan balik sebelum penyerahan Ajax
});
});



beforeCall Kaedah ini tidak akan dipanggil, jadi masih tidak boleh digunakan

4 Gunakan ajax untuk mengesahkan dan menyerahkan borang menggunakan ajax Kaedah ini mengelirukan, dan kaedah di atas untuk mengubah suai kod sumber tidak mudah digunakan.
Untuk kaedah ketiga dan keempat, penyelesaiannya adalah seperti berikut:

Tambahkan kawalan atribut tersuai="Nama pengguna,e-mel" pada teg borang yang menggunakan pengesahan ajax Nilai atribut ialah ID kawalan yang akan disahkan menggunakan ajax (berbilang kawalan dipisahkan dengan koma).

Salin kod

Kod adalah seperti berikut:
Tambahkan dua url atribut (alamat permintaan ajax) dan ralat (mesej gesaan apabila gagal) pada setiap kawalan yang perlu disahkan


Salin kod

Kod adalah seperti berikut:

Isytiharkan dua tatasusunan global dalam javascript

Salin kod Kod adalah seperti berikut:

var controlId = new Array(); //Simpan ID kawalan yang gagal pengesahan
var errors = new Array(); //Simpan mesej gesaan untuk pengesahan yang gagal

Ideanya ialah untuk mendapatkan nilai atribut kawalan pada teg borang (gunakan koma untuk memisahkan setiap ID kawalan), gunakan ajax untuk melintasi permintaan dan apabila pengesahan gagal, tambahkan ID kawalan dan maklumat segera kepada controlId dan ralat , dan maklumat segera Apabila menyerahkan borang, tentukan sama ada controlId itu kosong, maklumat segera akan dipaparkan dalam satu gelung

Salin kod Kod adalah seperti berikut:
$(function() {
var ajaxForm2Controls = $("form#ajaxForm2Controls") ; //Apabila borang diserahkan
$(ajaxForm2Controls).submit(function() {
ajaxForm2Control(ajaxForm2Controls) ;           kembali palsu ;                                     });
//Sahkan kawalan apabila hilang fokus
valControls(ajaxForm2Controls); });



Kaedah penghantaran borang:

Salin kod

Kod adalah seperti berikut: fungsi ajaxForm2Control(obj) { //Kembali apabila terdapat mesej ralat dan paparkan mesej ralat If(controlId.length > 0) {
alertinfo() ;
          pulangan palsu ;                                        }  
If(!$(obj).validationEngine("validate")) return false; //Sahkan kawalan yang tidak menggunakan pengesahan ajax (medan yang tidak disahkan ajax boleh disahkan seperti biasa, dan akan dikembalikan jika gagal)
$.ajax({
Taip: "POST",
URL: $(obj).attr("tindakan"),
Data: $(obj).serialize(),
Jenis Data: "html",
Kejayaan: fungsi(data){
                                                                                                                                                                                                              
});
}



Tambahkan acara fokus pada bentuk



Salin kod

Kod adalah seperti berikut:


//Kawalan yang perlu disahkan dalam borang
fungsi valControls(ajaxForm2Controls) {
//Dapatkan kawalan yang memerlukan pengesahan ajax
var controlsStr = ajaxForm2Controls.attr("control"); //Kembali apabila atribut tidak ditentukan
If(typeof(controlsStr) === "undefined" || controlsStr.length <= 0) return ; //Dapatkan ID kawalan
secara berasingan var controls = controlsStr.split(/,/g)
for(var i dalam kawalan) {
//Tambah fokus meninggalkan acara
           $("#" kawalan[i]).kabur(fungsi() { 
If($(this).val().length <= 0) return false; //Tetapkan semula tatasusunan
                  controlId.length = 0;                          errors.length = 0 ; //Mesej ralat
            var error = $(this).attr("error") ;  
$.ajax({
Taip: "DAPAT",
​​​​ url: $(this).attr("url"),
Data: $(this).serialize(),
Jenis Data: "teks",
Kejayaan: fungsi(data){
Jika(data==="benar") {
//Letakkan mesej ralat ke dalam tatasusunan jika pengesahan gagal
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                controlId.push(controls[i]);                                                         ralat. push(error);                                                                                                                                                                                                                                                                                                                                                                             alertinfo() ;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         });                                      }) ;                           }  
}



Mesej ralat:





Salin kod


Kod adalah seperti berikut:

//Mesej pop timbul
function alertinfo() {
If(controlId.length > 0) {
for(var i dalam controlId) {
//validationEngine kaedah, muncul gesaan untuk ID yang ditentukan                                                             // Penggunaan:$("#id").validationEnine("prompt.",">load // & lt; span style = "" & gt; buat prompt pada elemen ini, 3 menyatakan: "lulus", "ralat", "beban" & lt;/span & gt; & lt;/span & gt;                  $("#" controlId[i]).validationEngine("showPrompt", errors[i], "error");                                                                                                                    }  
}



Dengan cara ini, apabila kami menyerahkan borang dalam cara ketiga atau keempat, kami hanya boleh memanggil controlId untuk melihat sama ada terdapat nilai sebelum menyerahkan.

Kenyataan Laman Web ini
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

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

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan kaedah permintaan PUT dalam jQuery? Bagaimana untuk menggunakan kaedah permintaan PUT dalam jQuery? Feb 28, 2024 pm 03:12 PM

Bagaimana untuk menggunakan kaedah permintaan PUT dalam jQuery? Dalam jQuery, kaedah menghantar permintaan PUT adalah serupa dengan menghantar jenis permintaan lain, tetapi anda perlu memberi perhatian kepada beberapa butiran dan tetapan parameter. Permintaan PUT biasanya digunakan untuk mengemas kini sumber, seperti mengemas kini data dalam pangkalan data atau mengemas kini fail pada pelayan. Berikut ialah contoh kod khusus menggunakan kaedah permintaan PUT dalam jQuery. Mula-mula, pastikan anda memasukkan fail perpustakaan jQuery, kemudian anda boleh menghantar permintaan PUT melalui: $.ajax({u

PHP dan Ajax: Membina enjin cadangan autolengkap PHP dan Ajax: Membina enjin cadangan autolengkap Jun 02, 2024 pm 08:39 PM

Bina enjin cadangan autolengkap menggunakan PHP dan Ajax: Skrip sisi pelayan: mengendalikan permintaan Ajax dan mengembalikan cadangan (autocomplete.php). Skrip pelanggan: Hantar permintaan Ajax dan cadangan paparan (autocomplete.js). Kes praktikal: Sertakan skrip dalam halaman HTML dan nyatakan pengecam elemen input carian.

Bagaimana untuk mendapatkan pembolehubah daripada kaedah PHP menggunakan Ajax? Bagaimana untuk mendapatkan pembolehubah daripada kaedah PHP menggunakan Ajax? Mar 09, 2024 pm 05:36 PM

Menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP adalah senario biasa dalam pembangunan web Melalui Ajax, halaman boleh diperoleh secara dinamik tanpa menyegarkan data. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP, dan memberikan contoh kod khusus. Pertama, kita perlu menulis fail PHP untuk mengendalikan permintaan Ajax dan mengembalikan pembolehubah yang diperlukan. Berikut ialah kod contoh untuk fail PHP mudah getData.php:

Petua jQuery: Cepat ubah suai teks semua teg pada halaman Petua jQuery: Cepat ubah suai teks semua teg pada halaman Feb 28, 2024 pm 09:06 PM

Tajuk: Petua jQuery: Cepat ubah suai teks semua teg pada halaman Dalam pembangunan web, kita selalunya perlu mengubah suai dan mengendalikan elemen pada halaman. Apabila menggunakan jQuery, kadangkala anda perlu mengubah suai kandungan teks semua teg dalam halaman sekaligus, yang boleh menjimatkan masa dan tenaga. Berikut akan memperkenalkan cara menggunakan jQuery untuk mengubah suai teks semua teg pada halaman dengan cepat, dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan fail perpustakaan jQuery dan memastikan bahawa kod berikut dimasukkan ke dalam halaman: &lt

Gunakan jQuery untuk mengubah suai kandungan teks semua teg Gunakan jQuery untuk mengubah suai kandungan teks semua teg Feb 28, 2024 pm 05:42 PM

Tajuk: Gunakan jQuery untuk mengubah suai kandungan teks semua teg jQuery ialah perpustakaan JavaScript yang popular yang digunakan secara meluas untuk mengendalikan operasi DOM. Dalam pembangunan web, kita sering menghadapi keperluan untuk mengubah suai kandungan teks tag pautan (tag) pada halaman. Artikel ini akan menerangkan cara menggunakan jQuery untuk mencapai matlamat ini dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan perpustakaan jQuery ke dalam halaman. Tambahkan kod berikut dalam fail HTML:

PHP lwn. Ajax: Penyelesaian untuk mencipta kandungan yang dimuatkan secara dinamik PHP lwn. Ajax: Penyelesaian untuk mencipta kandungan yang dimuatkan secara dinamik Jun 06, 2024 pm 01:12 PM

Ajax (JavaScript Asynchronous dan XML) membenarkan menambah kandungan dinamik tanpa memuatkan semula halaman. Menggunakan PHP dan Ajax, anda boleh memuatkan senarai produk secara dinamik: HTML mencipta halaman dengan elemen kontena dan permintaan Ajax menambah data pada elemen selepas memuatkannya. JavaScript menggunakan Ajax untuk menghantar permintaan kepada pelayan melalui XMLHttpRequest untuk mendapatkan data produk dalam format JSON daripada pelayan. PHP menggunakan MySQL untuk menanyakan data produk daripada pangkalan data dan mengekodnya ke dalam format JSON. JavaScript menghuraikan data JSON dan memaparkannya dalam bekas halaman. Mengklik butang mencetuskan permintaan Ajax untuk memuatkan senarai produk.

Fahami peranan dan senario aplikasi eq dalam jQuery Fahami peranan dan senario aplikasi eq dalam jQuery Feb 28, 2024 pm 01:15 PM

jQuery ialah perpustakaan JavaScript popular yang digunakan secara meluas untuk mengendalikan manipulasi DOM dan pengendalian acara dalam halaman web. Dalam jQuery, kaedah eq() digunakan untuk memilih elemen pada kedudukan indeks tertentu Senario penggunaan dan aplikasi khusus adalah seperti berikut. Dalam jQuery, kaedah eq() memilih elemen pada kedudukan indeks yang ditentukan. Kedudukan indeks mula dikira dari 0, iaitu indeks elemen pertama ialah 0, indeks elemen kedua ialah 1, dan seterusnya. Sintaks kaedah eq() adalah seperti berikut: $("s

Bagaimana untuk mengetahui sama ada elemen jQuery mempunyai atribut tertentu? Bagaimana untuk mengetahui sama ada elemen jQuery mempunyai atribut tertentu? Feb 29, 2024 am 09:03 AM

Bagaimana untuk mengetahui sama ada elemen jQuery mempunyai atribut tertentu? Apabila menggunakan jQuery untuk mengendalikan elemen DOM, anda sering menghadapi situasi di mana anda perlu menentukan sama ada sesuatu elemen mempunyai atribut tertentu. Dalam kes ini, kita boleh melaksanakan fungsi ini dengan mudah dengan bantuan kaedah yang disediakan oleh jQuery. Berikut akan memperkenalkan dua kaedah yang biasa digunakan untuk menentukan sama ada elemen jQuery mempunyai atribut khusus, dan melampirkan contoh kod tertentu. Kaedah 1: Gunakan kaedah attr() dan operator jenis // untuk menentukan sama ada elemen mempunyai atribut tertentu

See all articles