Send dynamic email from HTML & CSS template – PHP
By the end of this tutorial, you will be able to send a dynamic email in PHP. Along with any beautifully designed template in HTML, CSS or Bootstrap. We will be using the template named “Invoice” from this website:
https://www.dyspatch.io/resources/templates/airmail/
It’s a pretty basic template and great to learn.
After downloading the template, you will see something like this:
All are static values. So let’s make them dynamic.
First you have to put all the template code in 1 separate file and named it “payment.php”, make sure to have all CSS code in this file. No external CSS file should be used because it will not appear in email.
Now, you have to replace the values you want to change and replace them with {{key}} for example, if you want to make coupon code dynamic, you will do something like this:
Coupon code {{coupon_code}}
Now, coming back to the file from where you want to send email, let’s say “send-mail.php”, first you have to get the template file by:
<?php
$email = file_get_contents("payment.php");
echo $email;
?>
This will display your email template in “send-mail.php” file. In order to replace the {{coupon_code}} with your dynamic value, you have to use the str_replace function of PHP. It accepts 3 parameters:
- Value to be replaced
- New value
- String from which to replace
<?php
$email = file_get_contents("payment.php");
$email = str_replace("{{coupon_code}}", "1234567", $email);
echo $email;
?>
Now we are going to add {{key}} on every static value in template which needs to be dynamic. After that, you need to create an array in your “send-mail.php” file and use the same function for all static values.
<?php
$email = file_get_contents("payment.php");
$email = str_replace("{{coupon_code}}", "1234567", $email);
$variables = array(
"{{coupon_code}}" => 1234,
"{{invoice}}" => 5678,
"{{card_ending}}" => 9876,
"{{username}}" => "Adnan"
);
foreach ($variables as $key => $value)
$email = str_replace($key, $value, $email);
echo $email;
?>
Now, you will be able to see your template with correct values. You can send the mail using the following 2 methods:
- PHP built-in mail() function
- Using PHPMailer library
Built-in mail() function
You can call the function:
<?php
// Your subject goes here
$subject = 'Payment Invoice';
$headers = "MIME-Version: 1.0\r\n";
$headers .= "Content-Type: text/html; charset=ISO-8859-1\r\n";
// Enter receiver's email address
mail("receiver_email@gmail.com", $subject, $email, $headers);
?>
Using PHPMailer library
You can install the library using composer in your project:
composer require phpmailer/phpmailer
and follow the guide from here: https://github.com/PHPMailer/PHPMailer
If you do not want to use composer, you can download manually from the following link and follow the guide: https://github.com/adnanafzal565/php-mailer
Hit the “send mail” button and you will receive an email similar to this:
So that’s how you can send a dynamic email in PHP from any HTML template. Also, learn how you can attach a link to the file to download in an email from here.
If you have any problems in following this, feel free to ask in the comments section below.
[wpdm_package id=’76’]
Hi Adnan, this was very informative. Thanks a lot for this. I’m facing an issue to use foreach loop in this. I want to render a section of html content based on the number of entries in an array. Could you please guide me how I can do it?
Yes, what error are you seeing ?