for (var i = 0; i < 250; i++) {
var response = await $.ajax('api/page=' + i);
console.log('Получены данные:');
console.dir(response);
// Здесь впиши условие остановки:
if (условие) {
i = 250; // Увеличиваем счетчик до 250, это приведет к остановке цикла
}
}
// Здесь пиши дальше свой код
$(function () {
$("#ajax_form").submit(
async function(event) {
var form = new FormData(event.target);
event.preventDefault();
try {
var response = await $.ajax({
url: 'create-article.php',
type: 'POST',
data: form,
processData: false,
contentType: false
});
console.log("Ответ серввера:\n" + response);
alert("Ответ серввера:\n" + response);
}
catch(err) {
alert('Ошибка отправки, детали см. в консоли!');
console.log('Не удалось отправить форму:');
console.error(err);
}
}
);
});
// Ждем когда элементы на странице прогрузятся:
document.addEventListener('DOMContentLoaded', function() {
// Вешаем на кпопку обработчик клика, чтобы при каждом клике
// сразу запускалась функц я dataSend отвечающая за отправку данных:
document.querySelector('.button').addEventListener('click', dataSend);
});
// Функция для отправки данных на сервер:
async function dataSend() {
// Получаем данные с нужных нам полей в переменные:
var loginValue = document.querySelector('.login').value
var emailValue = document.querySelector('.email').value
var passwordValue = document.querySelector('.password').value
var conf_passwordValue = document.querySelector('.conf_password').value
// Создаем объект с данными:
var data = {
'login': loginValue,
'email': emailValue,
'password': passwordValue,
'conf_password': conf_passwordValue
}
// Конвертируем объект в JSON:
var json = JSON.stringify(data);
// Отправялеям полученный JSON на сервер обычным POST-запросом:
var response = await (await fetch('https://yousite.ru/handler.php', {
'method': 'POST',
'headers': {
'Content-Type': 'application/json; charset=utf-8'
},
'body': json
})).text();
// Выводим ответ сервера в консоли:
console.log('Ответ сервера:');
console.log(response);
}
<?php
// Включим показ ошибок:
ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);
// Считываем полученный JSON:
$json = file_get_contents('php://input');
// Раскодируем JSON в массив:
$array = json_decode($json, true);
// Выведем массив, чтобы посмотиеть, что в нем:
header('Content-Type: text/plain; charset=UTF-8'); // Указыавем браузеру, что ответ будет обычным текстом
echo "Из браузера получены следующие данные:\n"; // Выведем текст-предупреждение
print_r($array); // Выведем все, что находится в массиве
// Тестовый объект:
test_obj = {
'per1': 'Привет!',
'per2': 'Это проверка!',
'per3': new File(['Привет, мир!'], 'test.txt', {type: 'text/plain'})
};
// Тестовая отправка:
await multipartSend(test_obj);
// Функция для отправки данных:
async function multipartSend(obj) {
// Генерируем уникальный разделитель:
var boundary = '----WebKitFormBoundary';
var symbols = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for (var i = 0; i < 18; i++) { boundary += symbols.charAt(Math.floor(Math.random() * symbols.length)); }
var arr = [ ]; // Массив для записи тела запроса
// Перебираем свойства отправляемого объекта:
for (key in obj) {
// Если текущее свойство объекта строка или число:
if (typeof obj[key] == 'string' || typeof obj[key] == 'number') {
// Добавляем значение текущего параметра в массив как строку, разумеется вместе с разделителем и метаданными:
arr.push("--" + boundary + "\r\nContent-Disposition: form-data; name=\"" + key + "\"\r\n\r\n" + obj[key] + "\r\n");
}
// Если текущее свойство объекта файл:
else if (typeof obj[key] == 'object') {
if (typeof obj[key]['name'] !== 'undefined' && typeof obj[key]['type'] !== 'undefined') {
// Добавляем метаданные от файла и разделитель, как обычную строку:
arr.push("--" + boundary + "\r\nContent-Disposition: form-data; name=\"" + key.replace(/\[[0-9]*\]$/, '[]') + "\"; filename=\"" + obj[key]['name'] + "\"\r\nContent-Type: " + obj[key]['type'] + "\r\n\r\n");
arr.push(obj[key]); // Сам файл добавляем целиком, как есть
arr.push("\r\n"); // И не забываем про перенос строкки с конца
}
}
}
arr.push("--" + boundary + "--\r\n"); // Добавляем последний разделитель в массив
var body = new Blob(arr); // Формируем тело запроса (бинарник) для отправки из собранного ранее массива
// Отправляем бинарник и смотрим результат:
var response = await (await fetch('https://nadim.work/test.php', {
'method': 'POST',
'headers': {
'Content-Type': 'multipart/form-data; boundary=' + boundary
},
'body': body
})).text();
console.log(response);
return response;
}
https://yousite.ru/include/ajax.php?per1=test&per2=test
$(document).on('submit', '#form-job-modal-wrapper', function (e) {
$.ajax({
type: 'POST',
url: 'action_ajax_form.php',
data: new FormData(this),
success: (data) => {
$('#jobModal').html(data);
$( window ).resize();
}
});
e.preventDefault();
});
async function sendInfo() {
let arr1 = [1, 2, 3, 4, 5];
let arr2 = ['a', 'b', 'c', 'd', 'e'];
var response = await $.ajax({
url: 'test.php',
method: 'POST',
cache: false,
data: {
'arr1': arr1,
'arr2': arr2
}
});
console.log('Данные успешно отправлены, ответ сервера: ' + response);
return response;
}
</head>
на своем сайте следующий скрипт:<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>