Heim >Web-Frontend >js-Tutorial >Verwenden Sie AJAX und PHP, um Ihre Mailingliste zu erstellen
Die Schönheit dieses Setups ist, dass die Struktur der Seite vollständig von ihrer Funktionalität isoliert ist, was die Entwicklung und Wartung problemlos macht.
Innerhalb des JS -Ordners neben der Datei prototype.js befindet sich eine Datei namens MailingList.js. Diese Datei enthält den Code, der die für diese Seite spezifische AJAX -Funktionsfunktion ansteuert. Unser erstes Geschäftselement in dieser Datei ist es, dem Subulationsereignis des Formularelements einen Ereignishörer hinzuzufügen, wodurch der Ajax -Anruf zum Server ausgelöst wird. Wir können dies jedoch nicht sofort tun - wir müssen warten, bis die Seite geladen ist, was durch das Ladeereignis des Fenstersobjekts zutreffend ist.
Um diese Ereignishörer hinzuzufügen, verwenden wir die praktische Beobachtungsmethode des Prototyps. Wir fügen zunächst einen Hörer für das Load -Ereignis der Seite hinzu. In diesem Hörer fügen wir einen Event -Hörer dem Submit -Event unseres Formulars hinzu:
// Attach handler to window load event <br> Event.observe(window, 'load', init, false); <br> <br> function init() { <br> // Attach handler to form's submit event <br> Event.observe('addressForm', 'submit', storeAddress); <br> }
Beachten Sie, dass der Ereignishörer für unser Formular die JavaScript -Funktion Storaddress aufruft, wenn das Formular eingereicht wird. Diese Storadress -Funktion enthält das JavaScript, um einen Ajax -Aufruf an unser PHP -Skript zu tätigen. So sieht es aus:
function storeAddress(e) { <br> // Update user interface <br> $('response').innerHTML = 'Adding email address...'; <br> // Prepare query string and send AJAX request <br> var pars = 'address=' + escape($F('address')); <br> var myAjax = new Ajax.Updater('response', 'ajaxServer.php', {method: 'get', parameters: pars}); <br> // Stop form from submitting when JavaScript is enabled <br> Event.stop(e); <br> }
Diese Funktion ist sehr einfach. Es beginnt damit, dass der Benutzer etwas passiert, indem es eine Nachricht "E -Mail -Adresse hinzufügen ..." anzeigt. Als nächstes sammeln wir die Informationen aus dem Formular, um sich auf das Versenden einer AJAX -Anfrage vorzubereiten. Beachten Sie, wie wir auf den Inhalt des Textfelds mithilfe von Prototypen $ F -Funktion zugreifen, wodurch der Wert eines bestimmten Formularelements angezeigt wird, wenn sie mit der ID dieses Formularelements geliefert werden. Wir verwenden die JavaScript Escape -Funktion, um die Benutzereingabe in das Unicode -Format umzuwandeln. Auf diese Weise ist die URL bereit für die Lieferung an das PHP -Skript über die GET -Methode.
kommt dann der wichtigste Teil dieser Funktion: die Erstellung eines neuen Ajax.Updater -Objekts. Wenn wir ein Ajax.Updater -Objekt erstellen, übergeben wir einige Parameter, einschließlich:
Der Ajax.UpDater sendet die E -Mail -Adresse an den Server und wartet geduldig auf eine Antwort. Wenn es eine Antwort empfängt, werden sie anstelle der Nachricht „E -Mail -Adresse hinzufügen…“ zu Beginn der Methode angezeigt. Schließlich rufen wir Event an.
Einrichten Sie Ihre Mailinglistendatenbank// Attach handler to window load event <br> Event.observe(window, 'load', init, false); <br> <br> function init() { <br> // Attach handler to form's submit event <br> Event.observe('addressForm', 'submit', storeAddress); <br> }
im Codearchiv enthalten ist eine PHP -Datei namens createStable.php, die diese Tabelle für Sie erstellt. Bevor Sie diese Datei ausführen, müssen Sie jedoch die Datei dbConstants.php mit den Details Ihrer MySQL -Datenbank aktualisieren. Ich schlage vor, Sie aktualisieren diese Datei jetzt, da wir diese Konstanten im nächsten Abschnitt verwenden.
Wir haben alles eingerichtet, um die Adresse an den Server zu liefern. Jetzt wird PHP den Prozess beenden, indem die Adresse in Ihrer Datenbank gespeichert und eine Zeichenfolge in unser AJAX -Objekt zurückgegeben wird, um Erfolg oder Misserfolg anzuzeigen. Schauen wir uns die Datei ajaxServer.php an, an die die E -Mail -Adresse gesendet wird.
function storeAddress(e) { <br> // Update user interface <br> $('response').innerHTML = 'Adding email address...'; <br> // Prepare query string and send AJAX request <br> var pars = 'address=' + escape($F('address')); <br> var myAjax = new Ajax.Updater('response', 'ajaxServer.php', {method: 'get', parameters: pars}); <br> // Stop form from submitting when JavaScript is enabled <br> Event.stop(e); <br> }
Dieses sehr einfache PHP -Skript nennt eine Funktion namens Storadresse und kehrt zum AJAX -Objekt zurück, die von Storadress zurückgegebene Nachricht. Die Kommunikation mit dem Ajax -Objekt ist so einfach wie das Drucken einer Zeichenfolge.
Das erste, was Storaddress tut, ist eine Variable namens $ message in einen nicht bahnbrechenden Raum zu initialisieren. Anschließend stellt es sicher, dass das Skript eine E -Mail -Adresse in der Abfragezeichenfolge erhalten hat. Wenn dies nicht der Fall ist, lassen wir $ Message Variable als nicht bahnbrechenden Raum eingestellt. $ meldung wird am Ende dieser Funktion an den Anrufer zurückgegeben.
CREATE TABLE `mailinglist` ( <br> `id` INT NOT NULL AUTO_INCREMENT , <br> `email` TEXT NOT NULL , <br> PRIMARY KEY ( `id` ) <br> );
Sobald wir sicher sind, dass wir eine E -Mail -Adresse haben, mit der wir arbeiten können, möchten wir sicherstellen, dass es sich um eine gültige Adresse handelt. Wir werden einen regulären Ausdruck verwenden, um nach einigen alphanumerischen Zeichen zu suchen, gefolgt von dem @ -Symbol, mehr alphanumerischen Zeichen, einer Zeit und einigen mehr alphanumerischen Zeichen. Wenn dieser Test fehlschlägt, setzen wir $ Message auf eine Fehlermeldung und informieren den Benutzer, dass die eingegebene E -Mail -Adresse ungültig war:
<?php <br> require_once("inc/storeAddress.php"); <br> echo(storeAddress()); <br> ?>
Wenn die Adresse diesen Test bestehen, speichern wir ihn in der Datenbank. Dazu stellen wir eine Verbindung zu MySQL her, wählen die Datenbank aus und führen unsere Einfügungsabfrage aus. Wenn die Adresse ordnungsgemäß gespeichert wurde, setzen wir $ Message auf eine Erfolgsnachricht. Andernfalls setzen wir $ message auf eine Fehlermeldung.
function storeAddress() { <br> $message = " "; <br> // Check for an email address in the query string <br> if( !isset($_GET['address']) ){ <br> // No email address provided <br> }
Schließlich geben wir $ message an ajaxServer.php:
zurückelse { <br> // Get email address from the query string <br> $address = $_GET['address']; <br> // Validate Address <br> if(!preg_match("/^[_a-z0-9-]+(.[_a-z0-9-]+)*@ <br> [a-z0-9-]+(.[a-z0-9-]+)*$/i", $address)) { <br> $message = "<strong>Error</strong>: An invalid email address was provided."; <br> }
Laden Sie nun die Seite, geben Sie Ihre E -Mail -Adresse ein und senden Sie das Formular ein. Sie sollten Ihre E -Mail -Adresse ohne das Nachladen der Mailinglist -Tabelle angezeigt werden. Selbst wenn Sie JavaScript deaktivieren, funktioniert die Seite sehr ähnlich, außer dass sie mit JavaScript dynamisch die Ausgabe von Storaddress in die Seite einfügen, sondern direkt in den PHP -Code der Seite in die HTML eingefügt wird.
.ajax macht sich wirklich ein Anmelden für Ihre Mailingliste ein Stück Kuchen. Es wird nicht darauf gewartet, dass die Seite neu lädt, wodurch die Browsing -Erfahrung Ihres Besuchers unterbricht, und diejenigen, die mit JavaScript deaktiviert sind, müssen nicht ausgeschlossen werden. Der Prototyp macht den Prozess des Aufbaus von Ajax -Funktionen schnell und schmerzlos und ermöglicht es Ihnen, mit den Lüfter Ihrer Website in Kontakt zu bleiben.
Das obige ist der detaillierte Inhalt vonVerwenden Sie AJAX und PHP, um Ihre Mailingliste zu erstellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!