簡體   English   中英

使用 jQuery 和 ajax 在 WordPress 中發送電子郵件

[英]Sending email in WordPress using jQuery and ajax

我這里有一個小問題。 我正在 wordpress 上編寫一個簡單的報價表。 我有兩種形式,第一種形式將數據發送到執行所有計算的 jQuery(選項很少,所以我們沒有使用 DB),然后打印一個 html 行。 沒有問題,直到這里; 當我嘗試將該行/行發送到 PHP 以發送簡單的電子郵件時,問題就開始了。 我試過 ajax 和 wp_mail 但沒有成功。 這是我嘗試過的:

wordpress 模板文件中的 HTML:

<!--first form with data to calculate-->
 <form class="needs-validation">
  <!--select fields, no problem here-->
 </form>
  <div class="table-responsive"> <!--risultato preventivo-->
            <table class="table table-bordered" id="dynamic_field">
                <tr>
                    <!--result given by jQuery-->
                </tr>
            </table>
   <p id="total"><!--total price passed by jQuery--></p>
   </div>

   <!--second form for sending email-->
   <form action="#" method="POST">
            Nome:<br>
            <input type="text" name="nome" id="nome">
            <br>
            Cognome:<br>
            <input type="text" name="cognome" id="cognome">
            <br>
            Email:<br>
            <input type="email" name="email" id="email">
            <input type="hidden" name="invia" value="s">
            <input type="submit" id="inviaForm" value="Invia">
        </form>
        <div id="worked"></div>

在文件 main.js 中帶有 calcs 的 jQuery:

(function ($) {
   $(document).ready(function () {

      function generaRisultato (riga,nProfilo,nColore,nSerramento,costoRiga){
        var risultato = '<tr id="row' + riga +
         '" class="dynamic-added"><td><div><h5 class="my-0">Articolo: ' + nProfilo +
         '</h5><br><small class="text-muted">Colorazione: ' + nColore +
         '</small><br><small class="text-muted">Serramento: ' + nSerramento +
         '</small></div><span id="costo-riga'+riga+'">'+costoRiga+'€</span></td>'+
         '<td><button type="button" name="remove" id="'+ riga +'" class="btn btn_remove">-</button> 
         </td></tr>';
        return risultato;    
       }
        //calcs done correctly
        $('#dynamic_field').append(generaRisultato(i,profile,color,name,price)); //result printed

       var risultatoFinale = $('#dynamic_field').html(); //variable with result stored for email


       //sending form mail ajax
    $('#inviaForm').on('submit', function(e){
    //evito l'invio del form
    e.preventDefault(); 

    //recupero i valori
    var nomeUser = $('#nome').val();
    var cognomeUser = $('#cognome').val();
    var emailUser = $('#email').val();
    var totaleFinale = $('#totale').html();
    var preventivoFinale = $('#dynamic_field').html();

    //eseguo la chiamata ajax
    $.ajax({
      type: "POST",
      url: my_vars.ajaxurl, 
      data: {
        action : 'invio_mail', //azione da eseguire
        _nonce : my_vars.nonce,
        nome : nomeUser,
        cognome : cognomeUser,
        email : emailUser,
        totale : totaleFinale,
        preventivo : preventivoFinale
      },
      success: function(res){
        $('#funzionante').html(res);
      }
    });
  });

   });
 })(jQuery);

PHP里面的functions.php:

function vf_load_theme_preventivatore(){
wp_register_script('main', get_template_directory_uri().'/preventivatore/js/main.js', false, false, 
true);
wp_enqueue_script('main');

wp_localize_script( 'main', 'my_vars', array(
    'ajaxurl' =>admin_url('admin-ajax.php'),
    'nonce' => wp_create_nonce('invio-mail-nonce')
));
}
add_action('wp_enqueue_scripts', 'vf_load_theme_preventivatore');

function invio_mail_ajax(){
//verifico che il nonce sia corretto
if(!wp_verify_nonce( $_REQUEST['_nonce'], 'invio-mail-nonce') ){
    die('Non autorizzato!');
}

//Prepariamo le variabili da usare
$successo = '';
$nome = strval($_REQUEST['nome']);
$cognome = strval($_REQUEST['cognome']);
$email = $_REQUEST['email'];
$preventivo = $_REQUEST['preventivo'];
$totale = $_REQUEST['totale'];

//script mail
$header = "From: Site <test@site-domain.it>\n";
$header .= "BCC: Altro Ricevente <test2@my-domain.it>\n";
// costruiamo le intestazioni specifiche per il formato HTML
$header .= "Content-Type: text/html; charset=\"UTF-8\"\n";
$oggetto = "Ecco il tuo preventivo";
$messaggio = "<html><body><p>Richiesta preventivo da sito</p><p>Nome: ".$nome."</p><p>Cognome: 
 ".$cognome."</p><p>Email: ".$email."</p> <p>Dati del preventivo</p><p>".$preventivo."</p><p>Totale: 
 ".$totale."€</p></body></html>";
$inviata = wp_mail($email,$oggetto,$messaggio,$header);

$successo .= '<p>'.$nome.'</p>';

echo $successo;

die();

if($inviata){
    $successo = '<p> email invata</p>';
    echo $successo;
    die();
 } else die('errore nella mail');
}
add_action('wp_ajax_invio_mail','invio_mail_ajax');
add_action('wp_ajax_nopriv_invio_mail','invio_mail_ajax');

這就是我所做的,我只是隱藏了 jQuery 計算,因為它完美無缺。 我想發送一封帶有 html 格式文本的電子郵件,使用此解決方案,電子郵件甚至沒有發送(在將 ajax 和 php 腳本放入函數之前,電子郵件到達,php 在模板文件中),我也無法通過 html帶有結果的表格行和引用總數。 也許我弄錯了 ajax 或 php 部分。 有什么幫助嗎? 感謝你的支持!

創建 AJAX 提交表單。 經測試運行良好,您可以更改數據。 希望這對你有幫助。

復制並粘貼到您的 function.php 文件中

function invio_mail(){
$to = 'sendto@example.com';
$subject = 'The subject';
$body = 'The email body content';
$headers = array('Content-Type: text/html; charset=UTF-8');

wp_mail( $to, $subject, $body, $headers );
echo 'mail send';
die;
}
add_action("wp_ajax_invio_mail", "invio_mail");
add_action("wp_ajax_nopriv_invio_mail", "invio_mail");

只需粘貼您想要的頁面(表單)

<form id="ajaxformid" action="#" method="POST">
        Nome:<br>
        <input type="text" name="nome" id="nome">
        <br>
        Cognome:<br>
        <input type="text" name="cognome" id="cognome">
        <br>
        Email:<br>
        <input type="email" name="email" id="email">
        <input type="hidden" name="invia" value="s">
        <input type="submit" id="inviaForm" value="Invia">
</form>

只需粘貼在頁腳

<script>
 jQuery(document).ready(function($) {   
    var frm = $('#ajaxformid');
    frm.submit(function (e) {
        var formData = {
            nome: jQuery('#nome').val(),
            cognome: jQuery('#cognome').val(),
            email: jQuery('#email').val(),
            action:'invio_mail'
        };
        $.ajax({
            type        : 'POST', 
            url         : "<?php echo admin_url('admin-ajax.php'); ?>",
            data        : formData,
            dataType    : 'json',
            encode          : true
        }).done(function(data) {
            console.log(data);        
        }).fail(function(data) {
            console.log(data);

        });
        e.preventDefault();     
    });

  });
</script>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM