我有一个PHP脚本,临时上传CSV。重新加载一页CSV数据是从$_FILES
获取的,并转换为JSON数组。
然后,我使用$.each
遍历CSV行。
对于每一行,我对PHP函数执行一次AJAX调用,该函数设置一些订单跟踪数据并发送一封电子邮件。
由于电子邮件的限制,我想在每次循环迭代之间添加一个延迟。不过,我曾尝试在JavaScript中设置超时,但这并不起作用,我还试图在发送电子邮件之前添加一个PHP睡眠函数。
两种方法都不起作用,电子邮件仍然可以同时发送,没有延迟。
不管我添加的延迟如何,我发出的所有请求似乎都在一次处理中。
如何确保电子邮件发送延迟?
jQuery ($csv_rows是刚刚上传的CSV数据)
<script>
// Get CSV Rows into JSON array
var csvRows = '<?php echo json_encode( $csv_rows ); ?>';
var csvRows = ( jQuery.parseJSON( csvRows ) );
// Loop through each row
$.each( csvRows, function( key, value ) {
// Split row into array exploded by comma
row = value.toString().split( ',' );
// Get column values
order = row[0];
courier = row[1];
tracking = row[2];
// AJAX
var data = {
'action': 'shd_tracking_import',
'order': order,
'courier': courier,
'tracking': tracking,
};
// Do the ajax
$.ajax({
url: ajaxurl,
type: 'POST',
data: data,
success: function( response ) {
$( '#shd-import-results p' ).hide();
if( response !== '0' ) {
$( '#shd-import-results ul' ).append( response );
importedCount = parseInt( $( '#shd-import-progress span' ).text() );
$( '#shd-import-progress span' ).text( importedCount + 1 );
} else {
$( '<p>Error importing. Please ensure CSV meets requirements.</p>' ).appendTo( '#shd-import-results' );
}
}
});
});
</script>
PHP (这是AJAX中引用的shd_tracking_import操作)
if( isset( $_POST['order'] ) && isset( $_POST['courier'] ) && isset( $_POST['tracking'] ) ) {
// Delay (due to their Office 365 limits)
usleep( 4000000 ); // 4 Seconds (usleep used as sleep cannot contain fractions, usleep is microseconds, this was 2.5 seconds hence using usleep)
// My mailing function is here (which works just not delayed)
echo 'Done';
} else {
echo '0';
}
exit;
https://stackoverflow.com/questions/53819073
复制相似问题