Wyskakiwanie z HTML

Wszystko na zewnątrz tagów PHP jest ignorowane przez parser, co pozwala plikom PHP mieć mieszaną zawartość. To pozwala na zagnieżdżanie PHP w plikach HTML, na przykład w celu stworzenia szablonu.

<?php
<p>To zostanie zignorowane przez PHP i wyświetlone w przeglądarce.</p>
<?
php echo 'Podczas gdy to zostanie sparsowane.'?>
<p>To także zostanie zignorowane przez PHP i wyświetlone w przeglądarce.</p>
To działa tak, jak się spodziewano, ponieważ kiedy interpreter PHP natrafi na zamykający znacznik ?>, poprostu zaczyna wyświetlać cokolwiek znajdzie (z wyjątkiem bezpośrednio następującej nowej linii - zobacz oddzielanie instrukcji) dopóki nie natrafi na kolejny otwierający znacznik - chyba, że znajdzie się to wewnątrz instrukcji warunkowej; w tym wypadku interpreter najpierw sprawdzi wynik instrukcji, aby zdecydować co pominąć. Zobacz kolejny przykład:

Wykorzystanie struktur z warunkami

Przykład #1 Zaawansowane wyskakiwanie przy użyciu warunków

<?php if ($expression == true): ?>
  To pokaże się, jeżeli wyrażenie jest prawdziwe.
<?php else: ?>
  W przeciwnym wypadku pokaże się to.
<?php endif; ?>
W tym przykładzie PHP pominie bloki, gdzie warunek nie jest spełniony, nawet jeżeli są one poza tagami PHP. PHP pomija je odpowiednio do warunku, ponieważ interpreter przeskakuje bloki zawarte w instrukcji, która nie została spełniona.

Dla wyświetlania większych ilości tekstu, wyjście z trybu parsowania PHP jest ogólnie rzecz biorąc bardziej wydajne niż wysyłanie całego tekstu przez funkcje echo lub print.

W PHP 5 mamy do pięciu różnych par znaczników otwierających i zamykających, dostępnych w PHP, w zależności od tego jak skonfigurowano PHP. Dwie z nich, <?php ?> i <script language="php"> </script> są zawsze dostępne. Istnieje też krótkich znacznik echo <?= ?>, który jest zawsze dostępny w PHP 5.4.0 i nowszych.

Pozostałe dwa to krótkie znaczniki i znaczniki w stylu ASP. Część osób postrzega krótkie znaczniki i znaczniki w stylu ASP jako wygodne, jednakże są one mniej przenośne, i zasadniczo nie polecane.

Informacja:

Zauważ również, że jeśli zagnieżdzasz PHP w XML lub XHTML musisz stosować znaczniki <?php ?> aby pozostać w zgodzie ze standardami.

PHP 7 wycofało wsparcie dla tagów ASP i znaczników <script language="php">. W związku z tym zalecamy używać wyłącznie tagów <?php ?> and <?= ?>, aby maksymalnie zwiększyć kompatybilność kodu PHP.

Przykład #2 Znaczniki otwierające i zamykające PHP

1.  <?php echo 'jeśli chcesz obsługiwać dokumenty XHTML lub XML,
                użyj tych tagów'
?>

2.  Możesz użyć krótkiego znacznika echo do <?= 'wyświetlenia tego tekstu' ?>.
    Jest on zawsze dostępny w PHP 5.4.0 i nowszych i jest odpowiednikiem
    <?php echo 'wyświetlenia tego tekstu' ?>.

3.  <? echo 'this code is within short tags, but will only work '.
            'if short_open_tag is enabled'; ?>
                
4.  <script language="php">
        echo 'niektóre edytory (jak FrontPage) nie lubią
              instrukcji przetwarzania';
    </script>
    Ta składnia została usunięta w PHP 7.0.0.

5.  <% echo 'Możesz opcjonalnie użyć znaczników w stylu ASP'; %>
    Kod w znacznikach <%= $zmienna; jest skrótem dla kodu <% echo $zmienna; %>
    Obie te składnie zostały usunięte w PHP 7.0.0.

Krótkie znaczniki (trzeci przykład) są dostepne jedynie, kiedy są włączone za pomocą dyrektywy konfiguracyjnej short_open_tag w php.ini lub jeśli php zostało skonfigurowane z opcją --enable-short-tags .

Znaczniki w stylu ASP (piąty przykład) są dostępne jedynie gdy zostaną włączone poprzez dyrektywę konfiguracyjną asp_tags w php.ini i zostały usunięte w PHP 7.0.0.

Informacja:

Powinieneś unikać używania krótkich znaczników, kiedy rozwijasz aplikacje lub biblioteki, które są nastawione na rozpowszechnianie lub pracujesz na serwerach PHP, nad którymi nie masz kontroli, ponieważ krótkie znaczniki mogą nie być obsługiwane na docelowym serwerze. Dla przenośnego, rozpowszechnialnego kodu, miej pewność, aby nie użyć krotkich znaczników.

Informacja:

W PHP 5.2 i wcześniejszych, parser nie pozwalał, aby znacznik otwierający <?php był jedynym znakiem w pliku. Dozwolone jest to od PHP 5.3, pod warunkiem, że po tagu otwierającym znajduje się jeden lub więcej białych znaków (np. spacja).

Informacja:

Począwszy od PHP 5.4, krótkie znaczniki <?= są zawsze rozpoznawane i ważne, niezależnie od ustawień short_open_tag.

add a note add a note

User Contributed Notes 7 notes

up
339
quickfur at quickfur dot ath dot cx
9 years ago
When the documentation says that the PHP parser ignores everything outside the <?php ... ?> tags, it means literally EVERYTHING. Including things you normally wouldn't consider "valid", such as the following:

<html><body>
<p<?php if ($highlight): ?> class="highlight"<?php endif;?>>This is a paragraph.</p>
</body></html>

Notice how the PHP code is embedded in the middle of an HTML opening tag. The PHP parser doesn't care that it's in the middle of an opening tag, and doesn't require that it be closed. It also doesn't care that after the closing ?> tag is the end of the HTML opening tag. So, if $highlight is true, then the output will be:

<html><body>
<p class="highlight">This is a paragraph.</p>
</body></html>

Otherwise, it will be:

<html><body>
<p>This is a paragraph.</p>
</body></html>

Using this method, you can have HTML tags with optional attributes, depending on some PHP condition. Extremely flexible and useful!
up
95
ravenswd at gmail dot com
10 years ago
One aspect of PHP that you need to be careful of, is that ?> will drop you out of PHP code and into HTML even if it appears inside a // comment. (This does not apply to /* */ comments.) This can lead to unexpected results. For example, take this line:

<?php
  $file_contents 
= '<?php die(); ?>' . "\n";
?>

If you try to remove it by turning it into a comment, you get this:

<?php
//  $file_contents  = '<?php die(); ?>' . "\n";
?>

Which results in ' . "\n"; (and whatever is in the lines following it) to be output to your HTML page.

The cure is to either comment it out using /* */ tags, or re-write the line as:

<?php
  $file_contents 
= '<' . '?php die(); ?' . '>' . "\n";
?>
up
27
sgurukrupa at gmail dot com
6 years ago
Although not specifically pointed out in the main text, escaping from HTML also applies to other control statements:

<?php for ($i = 0; $i < 5; ++$i): ?>
Hello, there!
<?php endfor; ?>

When the above code snippet is executed we get the following output:

Hello, there!
Hello, there!
Hello, there!
Hello, there!
up
27
snor_007 at hotmail dot com
10 years ago
Playing around with different open and close tags I discovered you can actually mix different style open/close tags

some examples

<%
//your php code here
?>

or

<script language="php">
//php code here
%>
up
4
mike at clove dot com
9 years ago
It's possible to write code to create php escapes which can be processed later by substituting \x3f for '?' - as in echo "<\x3fphp echo 'foo'; \x3f>";

This is useful for creating a template parser which later is rendered by PHP.
up
-1
Emil Cataranciuc
2 years ago
"<script language="php"> </script>, are always available." since PHP 7.0.0 is no longer true. These are removed along the ASP "<%, %>, <%=" tags.
up
-20
admin at furutsuzeru dot net
11 years ago
These methods are just messy. Short-opening tags and ASP-styled tags are not always enabled on servers. The <script language="php"></script> alternative is just out there. You should just use the traditional tag opening:

<?php?>

Coding islands, for example:

<?php
$me
'Pyornide';
?>
<?=$me
;?> is happy.
<?php
$me
= strtoupper($me);
?>
<?=$me
;?> is happier.

Lead to something along the lines of messy code. Writing your application like this can just prove to be more of an
inconvenience when it comes to maintenance.

If you have to deal chunks of HTML, then consider having a templating system do the job for you. It is a poor idea to rely on the coding islands method as a template system in any way, and for reasons listed above.
To Top