duan19805 2014-07-23 22:59
浏览 21
已采纳

通过PHPmailer发送HTML表

I'm trying to send a dynamic HTML table with PHPmailer but i don't know how, is posible get a variable with all table? or something like that ?

Here is my code:

require("inc/class.phpmailer.php");
$mail = new PHPMailer();
$mail->CharSet = 'UTF-8';
$mail->From     = ('compras.co@kantarworldpanel.com');
$mail->FromName = ('Compras CO (KWBTA)');
$mail->AddAddress($_POST['providermail']);
$mail->AddCC("camilo.uribe@kantarworldpanel.com.co");    
$mail->IsHTML(true);        


 //IF SUBMIT, SEND MAIL 
 if (isset ($_POST['send_approve'])) {
$mail->Subject = "Kantar Worldpanel - Solicitud de Cotización";
$contenido =  'Kantar Worldpanel  Perú S.A. Sucursal Colombia desea solicitar a ustedes la cotización correspondiente a los siguientes Items:<br>';

////////////////////////////////////////////
$contenido .= ' The Table should be here;
///////////////////////////////////////////

$mail->Body    = $contenido;
$mail->Send();
header ("Location: RequestsPA.php");
}

And here is the table code:

<?php 
$sqlStr = "SELECT items.CA_id, items.item_id, items.item_Cant, items.CECO_cod, items.item_desc, items.item_enduser
FROM items where CA_id = ".$CA_id;
$sqlStrAux = "SELECT count(*) as total FROM items";

$aux = Mysql_Fetch_Assoc(mysql_query($sqlStrAux));
$query = mysql_query($sqlStr);  

if($aux['total']>0){

    echo "</br></br>";
    echo "<div class='datagrid'>";
    echo "\t<table class=\"tablesorter\">
";
    echo "<thead>";
    echo "<tr>
        <th>Item</th>
        <th>Cantidad</th>
        <th>CECO</th>
        <th>Descripción de solicitud</th>
        <th>Usuario final</th>          
      </tr>
";
    echo "</thead>";      
        echo "<tbody>";
        $r=0;
        while($row = mysql_fetch_assoc($query)){
    echo "\t\t<tr class=\"row$r\">
            <td>".htmlentities($row['item_id'])."</td>
            <td>".htmlentities($row['item_Cant'])."</td>
            <td>".htmlentities($row['CECO_cod'])."</td>
            <td>".$row['item_desc']."</td>
            <td>".$row['item_enduser']."</td>
                </tr>
";
      if($r%2==0)++$r;else--$r;
    }
    echo "</tbody>";                  
    echo "\t</table>
";
    }
    echo "</div>";
?>

I hope you can understand me, thanks for your help.

  • 写回答

2条回答 默认 最新

  • drqn5418 2014-07-24 08:01
    关注

    While you can use echo to output your table and capture it with output buffering, but generally it's easier to assemble the message body in a string, like this:

    $contenido = '';
    if($aux['total']>0){
    
        $contenido .= "</br></br>";
        $contenido .= "<div class='datagrid'>";
        $contenido .= "\t<table class=\"tablesorter\">
    ";
        $contenido .= "<thead>";
        ...
    

    Then just use that string as your message body. If you use the same code to generate web page output as your email content then turn that script into a function you can call from either place.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀