Reputation: 8105
Sorry for the silly question, but I ran across code that used:
<?=$MAP_OBJECT->printOnLoad();?>
<?=$MAP_OBJECT->printMap();?>
<?=$MAP_OBJECT->printSidebar();?>
Is there anything special about <?=
over <?php
or just plain <?
?
Upvotes: 12
Views: 5836
Reputation: 2805
adding this due to duplicate questions
<? ?>
aka shortags is an alternative tag for php but works only on servers that have it enabled.
It allows you to write echo like this <?=$var
However it is not recommended to use them and have been suggested to be removed or deprecated in php5.4+ along with register globals, safe mode and magic quotes etc.
So though you might use them, they are not recommended.
They are however great for making templates along with other shorthand notations for loops and conditional checks.
Upvotes: 0
Reputation: 2244
Inside short tag you cannot write like this .
<?=
$number = "5";
$sum = 15 + "5";
?>
because it will print only the first output as 5.
Inside open tag you can write like this .
<?php
echo $number ="5";
echo $sum = 15+"5";
?>
It will print both 5 and 20
its all about syntax.
Upvotes: 1
Reputation: 655359
Rather than talking about whether short_open_tags is deprecated or not we should talk about the advantages and disadvantages when using short open tags:
Using the short open tags <?
along with <?=
is shorter and probably easier to write than the standard opening tags <?php
and <?php echo
respectively. That’s quite handy when using PHP directly in a template. (That’s probably also the reason why PHP has an alternative syntax for control structures.)
When using short open tags you are required to have short_open_tags enabled. If you or your web hosting provider decides to disable short_open_tags, your application probably won’t work any more and you can have some serious security issues. Because if short_open_tags is disabled, only the standard opening tags <?php
are recognized and everything inside short opening tags is treated as plain text. (See also the blog post referenced in Sarfraz Ahmed’s answer.)
This requirement makes your PHP application less portable if you aim to write applications that are not just for you. That’a also why many recommend not to use short open tags (including the PHP manual):
Note: Using short tags should be avoided when developing applications or libraries that are meant for redistribution, or deployment on PHP servers which are not under your control, because short tags may not be supported on the target server. For portable, redistributable code, be sure not to use short tags.
As of PHP 5.4 <?=
is always available, regardless of the short_open_tags
option. <?
on the other hand requires the option to be enabled.
Another issue is when using XML processing instructions like <?xml … ?>
. When short_open_tags is enabled you cannot use them directly in your code but need to use PHP to output it:
If you want to use PHP in combination with XML, you can disable this option in order to use
<?xml ?>
inline. Otherwise, you can print it with PHP, for example:<?php echo '<?xml version="1.0"?>'; ?>
.
Otherwise PHP will choke on the xml
in <?xml
.
Now some last words about the deprecation: Currently short_open_tags is not deprecated. Otherwise the manual would state that explicitly. Additionally, Rasmus Lerdorf, inventor of PHP, wrote in a reply on the question “Is it true that short_open_tag is deprecated in PHP 6?” on the internals mailing list that there were several reasons not to remove short_open_tags in PHP 6:
Which is one of the reasons we decided not to remove them in PHP 6.
Upvotes: 14
Reputation: 224963
<?=
is a short tag that is pretty much equivalent to:
<?php echo
As of PHP 5.4, this syntax is always available, but in earlier versions of PHP, it needs short_open_tag
enabled. As for how to search for it on Stack Overflow, try code:"<?="
.
Upvotes: 12
Reputation: 382776
They are shorthand of <?php echo .... ?>
known as short tags. You should avoid using them because:
<?xml ... ?>
Therefore you should never use them again, also have a look at:
PHP Short Open Tag: Convenient Shortcut or Short Changing Security?
Upvotes: 18
Reputation: 157887
Just to correct all these misguiding answers:
short open tags are not going to be removed or deprecated.
Upvotes: 1
Reputation: 18798
<?=
is not one thing. It's actually <?
and then =
. As @derekerdmann has mentioned, this is an unrecommended configuration.
Give the following a look:
Upvotes: 1
Reputation: 18252
It's a shorthand for <?php echo $MAP_OBJECT->printOnLoad(); ?>
. Simpler way to write it when you're making PHP-based templates and things.
Be careful, though. My understanding (though I've never run into it myself) is that the shorthand version can be disabled on some servers.
Upvotes: 7