我有一封电子邮件发送给我的网站的订阅者.我是通过从数据库中获取订户列表,然后遍历数组并一次发送一封电子邮件来实现此目的的…我知道有一种方法可以一次发送所有邮件,但这就是为什么我要这样做我需要帮助…
{name}和{date}
我需要做的是在HTML电子邮件中插入替换{date}令牌的日期,并为每个电子邮件发送插入替换{name}的名称(因为名称总是不同的).
这就是我所拥有的:
$result = $wpdb->get_results( "SELECT * FROM wp_newsletter WHERE `id` IN ( $userIds )");
for($i = 0, $size = sizeof($result); $i < $size; ++$i){
add_filter('wp_mail_content_type',create_function('', 'return "text/html";'));
$to .= $result[$i]->name.'<'.$result[$i]->email.'>';
$mail = wp_mail( $to, $subject , $message, $headers);
}
如您在上面看到的,数据库中有两个变量:
$result [$i]->名称
$result [$i]->电子邮件
$message是HTML电子邮件正文,其中包含需要替换的2个令牌.
等等….一切正常,就可以正常循环和发送了,我只需要一些有关如何替换{name}和{date}令牌的帮助.
任何帮助,将不胜感激.
解决方法:
使用PHP的str_replace函数docs here可以轻松完成此操作.
...
$message = str_replace('{name}', $result[$i]->name, $message);
$message = str_replace('{date}', date('Y/m/d H:i:s'), $message); // Or your preferred date format
$mail = wp_mail( $to, $subject , $message, $headers);
请注意,如果您知道只有一个{name}和/或{date}实例,则可以将第四个参数$count传递给str_replace,并在替换第一个匹配项后退出.
干杯