sql >> Database teknologi >  >> RDS >> Mysql

Ekko i heredoc / nowdoc syntaks

Jeg tror, ​​det var det, du havde tænkt dig at gøre, det ser lidt akavet ud:

$fn = escape($mt->from_name);
$time = escape(date("F d, Y - h:i a", strtotime($mt->st_time)));
$stc = nl2br(escape($mt->st_content));

//START EMAIL
User::sendNewticket($send_to, 'Maintenance Ticket ' . Input::get('st_id'), <<<TEXT
Hello -<br><br>
TEXT
        . Input::get('rec_message') . <<<TEXT2
<br><br>

<strong>Conversation:</strong><br><br>

$fn<br>
$time<br>
$stc<br>

TEXT2
);

Starten på et heredoc skal være den sidste ting på en linje, så derefter falder du ned og går straks ind i tekstblokken. Slutningen af ​​heredoc'et skal være den eneste ting på linjen, så for at sammenkæde den skal du rulle ned en linje, før du kan bruge operatoren (. ). Du behøver heller ikke bruge anførselstegn eller tilføje operatorer, når du er inde i en herdok.

Det er faktisk så uintuitivt, at selv StackOverflow Syntax highlighteren tager fejl, den første <<<TEXT fungerer fint, da jeg kørte dette:

$mt = new stdClass();
function escape($v){return $v;}
class User{static function sendNewTicket($a, $b, $c){echo $c;}}
class Input{static function get($a){return 'Got something';}}
$send_to = '';
$mt->from_name = 'Kitty';
$mt->st_time = '5th November';
$mt->st_content = <<<CONTENT
    Dear Judy,

        Lorem Dipsum and all that jazz.

        Toodles,
            Kitty.
CONTENT;

$fn = escape($mt->from_name);
$time = escape(date("F d, Y - h:i a", strtotime($mt->st_time)));
$stc = nl2br(escape($mt->st_content));

//START EMAIL
User::sendNewticket($send_to, 'Maintenance Ticket ' . Input::get('st_id'), <<<TEXT
Hello -<br><br>
TEXT
        . Input::get('rec_message') . <<<TEXT2
<br><br>

<strong>Conversation:</strong><br><br>

$fn<br>
$time<br>
$stc<br>

TEXT2
);

Det producerede:

Hello -<br><br>Got something<br><br>

<strong>Conversation:</strong><br><br>

Kitty<br>
November 05, 2014 - 12:00 am<br>
    Dear Judy,<br />
<br />
        Lorem Dipsum and all that jazz.<br />
<br />
        Toodles,<br />
            Kitty.<br>

Selvom jeg er sikker på, at det vil se bedre ud med dine data.

Edit:Og som Blizz meget korrekt påpeger nedenfor, hvis du gemmer rec_message ind i en variabel, kan du helt undgå sammenkædningen:

$recMessage = Input::get('rec_message');
User::sendNewticket($send_to, 'Maintenance Ticket ' . Input::get('st_id'), <<<TEXT
Hello -<br><br>
$recMessage
<br><br>

<strong>Conversation:</strong><br><br>

$fn<br>
$time<br>
$stc<br>

TEXT
);

Rediger 2 :Med de ekstra beskeder, bør du bruge noget som dette for at forenkle e-mailen:

$messages = '';
foreach($st_messages->results() as $mt)
{

    $fn = escape($mt->from_name);
    $time = escape(date("F d, Y - h:i a", strtotime($mt->st_time)));
    $stc = nl2br(escape($mt->st_content));

    $messages .= <<<MESSAGE

$fn<br>
$time<br>
$stc<br><br>

MESSAGE;
}

$recMessage = Input::get('rec_message');
User::sendNewticket($send_to, 'Maintenance Ticket ' . Input::get('st_id'), <<<TEXT
Hello -<br><br>
$recMessage
<strong>Conversation:</strong><br><br>

$messages

Thanks,<br>
Support Team

TEXT
);
?>

Hvilket med nogle grundlæggende dummy tekst producerer:

Hello -<br><br>
Got something
<strong>Conversation:</strong><br><br>


Person<br>
November 11, 2014 - 12:00 am<br>
My message blah blah<br><br>

sdfasdf<br>
April 11, 2014 - 12:00 am<br>
My message asdfasdf blah blah<br><br>


Thanks,<br>
Support Team



  1. Hvordan kan jeg teste for null og ikke null på samme tid i sql?

  2. Mac OS X + Python + Django + MySQL

  3. Valg af et gennemsnit af poster grupperet efter 5 minutters perioder

  4. Vælg dato fra tidsstempel i SQLAlchemy