我有一封电子邮件发送给我的网站的订阅者.我是通过从数据库中获取订户列表,然后遍历数组并一次发送一封电子邮件来实现此目的的…我知道有一种方法可以一次发送所有邮件,但这就是为什么我要这样做我需要帮助…
{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,并在替换第一个匹配项后退出.
干杯
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。