Форум → Программирование → JavaScript → проверить данные POST и вывести сообщение без перезагрузки
проверить данные POST и вывести сообщение без перезагрузки
-
Заметил на некоторых сайтах одну очень прикольную фишку…
Допустим есть форма с различными полями
ФИО
e-mail
телефон
и кнопка отправить
и после того как пользователь нажмет на кнопку отправить форму, данные из полей
проверяються на корректность, телефон только из цифр или e-mail корректный чтобы был указан
и если поля некорректно заполнены то тутже выдается сообщение что мол вот тута и тута
непорядочек и форма не отправляется….а если все поля заполнены корректно то данные передаются следующему скрипту.
Как можно такое реализовать с помощью javascript…? -
-
21 ноября 2009 г. 21:59, спустя 25 минут 3 секунды
нашел кучу исчерпывающей информации…..огромное спасибо…
выкладываю очн прикольный код
// ———————————————————————-
// Javascript form validation routines.
// Author: Stephen Poley
//
// Simple routines to quickly pick up obvious typos.
// All validation routines return true if executed by an older browser:
// in this case validation must be left to the server.
//
// Update Jun 2005: discovered that reason IE wasn't setting focus was
// due to an IE timing bug. Added 0.1 sec delay to fix.
//
// Update Oct 2005: minor tidy-up: unused parameter removed
//
// Update Jun 2006: minor improvements to variable names and layout
// ———————————————————————-
var nbsp = 160; // non-breaking space char
var node_text = 3; // DOM text node-type
var emptyString = /^\s*$/ ;
var global_valfield; // retain valfield for timer thread
// ——————————————–
// trim
// Trim leading/trailing whitespace off string
// ——————————————–
function trim(str)
{
return str.replace(/^\s+|\s+$/g, '');
}
// ——————————————–
// setfocus
// Delayed focus setting to get around IE bug
// ——————————————–
function setFocusDelayed()
{
global_valfield.focus();
}
function setfocus(valfield)
{
// save valfield in global variable so value retained when routine exits
global_valfield = valfield;
setTimeout( 'setFocusDelayed()', 100 );
}
// ——————————————–
// msg
// Display warn/error message in HTML element.
// commonCheck routine must have previously been called
// ——————————————–
function msg(fld, // id of element to display message in
msgtype, // class to give element ("warn" or "error")
message) // string to display
{
// setting an empty string can give problems if later set to a
// non-empty string, so ensure a space present. (For Mozilla and Opera one could
// simply use a space, but IE demands something more, like a non-breaking space.)
var dispmessage;
if (emptyString.test(message))
dispmessage = String.fromCharCode(nbsp);
else
dispmessage = message;
var elem = document.getElementById(fld);
elem.firstChild.nodeValue = dispmessage;
elem.className = msgtype; // set the CSS class to adjust appearance of message
}
// ——————————————–
// commonCheck
// Common code for all validation routines to:
// (a) check for older / less-equipped browsers
// (b) check if empty fields are required
// Returns true (validation passed),
// false (validation failed) or
// proceed (don't know yet)
// ——————————————–
var proceed = 2;
function commonCheck (valfield, // element to be validated
infofield, // id of element to receive info/error msg
required) // true if required
{
if (!document.getElementById)
return true; // not available on this browser - leave validation to the server
var elem = document.getElementById(infofield);
if (!elem.firstChild) return true; // not available on this browser
if (elem.firstChild.nodeType != node_text) return true; // infofield is wrong type of node
if (emptyString.test(valfield.value)) {
if (required) {
msg (infofield, "error", "ERROR: required");
setfocus(valfield);
return false;
}
else {
msg (infofield, "warn", ""); // OK
return true;
}
}
return proceed;
}
// ——————————————–
// validatePresent
// Validate if something has been entered
// Returns true if so
// ——————————————–
function validatePresent(valfield, // element to be validated
infofield ) // id of element to receive info/error msg
{
var stat = commonCheck (valfield, infofield, true);
if (stat != proceed) return stat;
msg (infofield, "warn", "");
return true;
}
// ——————————————–
// validateEmail
// Validate if e-mail address
// Returns true if so (and also if could not be executed because of old browser)
// ——————————————–
function validateEmail (valfield, // element to be validated
infofield, // id of element to receive info/error msg
required) // true if required
{
var stat = commonCheck (valfield, infofield, required);
if (stat != proceed) return stat;
var tfld = trim(valfield.value); // value of field with whitespace trimmed off
var email = /^[^@][email protected][^@.]+\.[^@]*\w\w$/ ;
if (!email.test(tfld)) {
msg (infofield, "error", "ERROR: not a valid e-mail address");
setfocus(valfield);
return false;
}
var email2 = /^[A-Za-z][\w.-][email protected]\w[\w.-]+\.[\w.-]*[A-Za-z][A-Za-z]$/ ;
if (!email2.test(tfld))
msg (infofield, "warn", "Unusual e-mail address - check if correct");
else
msg (infofield, "warn", "");
return true;
}
// ——————————————–
// validateTelnr
// Validate telephone number
// Returns true if so (and also if could not be executed because of old browser)
// Permits spaces, hyphens, brackets and leading +
// ——————————————–
function validateTelnr (valfield, // element to be validated
infofield, // id of element to receive info/error msg
required) // true if required
{
var stat = commonCheck (valfield, infofield, required);
if (stat != proceed) return stat;
var tfld = trim(valfield.value); // value of field with whitespace trimmed off
var telnr = /^\+?[0-9 ()-]+[0-9]$/ ;
if (!telnr.test(tfld)) {
msg (infofield, "error", "ERROR: not a valid telephone number. Characters permitted are digits, space ()- and leading +");
setfocus(valfield);
return false;
}
var numdigits = 0;
for (var j=0; j<tfld.length; j++)
if (tfld.charAt(j)>='0' && tfld.charAt(j)<='9') numdigits++;
if (numdigits<6) {
msg (infofield, "error", "ERROR: " + numdigits + " digits - too short");
setfocus(valfield);
return false;
}
if (numdigits>14)
msg (infofield, "warn", numdigits + " digits - check if correct");
else {
if (numdigits<10)
msg (infofield, "warn", "Only " + numdigits + " digits - check if correct");
else
msg (infofield, "warn", "");
}
return true;
}
// ——————————————–
// validateAge
// Validate person's age
// Returns true if OK
// ——————————————–
function validateAge (valfield, // element to be validated
infofield, // id of element to receive info/error msg
required) // true if required
{
var stat = commonCheck (valfield, infofield, required);
if (stat != proceed) return stat;
var tfld = trim(valfield.value);
var ageRE = /^[0-9]{1,3}$/
if (!ageRE.test(tfld)) {
msg (infofield, "error", "ERROR: not a valid age");
setfocus(valfield);
return false;
}
if (tfld>=200) {
msg (infofield, "error", "ERROR: not a valid age");
setfocus(valfield);
return false;
}
if (tfld>110) msg (infofield, "warn", "Older than 110: check correct");
else {
if (tfld<7) msg (infofield, "warn", "Bit young for this, aren't you?");
else msg (infofield, "warn", "");
}
return true;
} -
21 ноября 2009 г. 23:18, спустя 1 час 19 минут 10 секунд
и "точка" :)
Полезная кнопка ghttps://smappi.org/ - платформа по созданию API на все случаи жизни -
22 ноября 2009 г. 9:44, спустя 10 часов 25 минут 32 секунды
выкладываю очн прикольный код
классный говнокод! давно такого тут не видел!!Сапожник без сапог -
-
22 ноября 2009 г. 23:50, спустя 9 часов 21 минуту 46 секунд
не знаю я ее немного переделал и все работает
Пожалуйста, авторизуйтесь, чтобы написать комментарий!