¿Por qué debería usar <?php
en lugar de <?
en mi script php?<? Php en lugar de <?
Respuesta
Las dos razones principales para evitar la etiqueta de apertura cortos son
- Máxima portabilidad -
<?php
funcionará en todos los servidores PHP habilitado, pero<?
se puede desactivar - Es idéntica a la apertura de la preámbulo XML - podría causar dolores de cabeza o la ejecución de análisis
El argumento XML no cuenta. (http: //hsivonen.iki. fi/producing-xml /). El argumento XML está en la misma categoría que la decisión sobre una forma no estándar de escapar cadenas de SQL. El equipo de PHP cometió un gran error y mató accidentalmente esta característica de etiqueta corta. – stesch
Cualquier administrador de servidor que deshabilita debe ser disparado. –
Jasper, por favor no abogue por dispararle a la gente a menos que esté dispuesto a mirar al objetivo a los ojos y apretar el gatillo usted mismo. –
Ambos son semánticamente iguales. <?
es simplemente un acceso directo para la sintaxis completa.
funciona exactamente igual en JSP – Vinze
Nick. ese código que mostré era para ASP.NET MVC y era simplemente una analogía –
Pero era una analogía incorrecta. PHP proporciona una etiqueta de utilidad como ASP.Net, pero es = Como se indicó en mi comentario anterior. Corrigió su respuesta, así que le di + 1. – nickohrn
Cabe señalar que algunas configuraciones de servidor de PHP no son compatibles con una u otra de manera predeterminada. Por ejemplo, mi servidor web no es compatible con <? pero admite <? php
Esto es técnicamente incorrecto: TODAS las instalaciones de php admiten la etiqueta de apertura normal (larga), mientras que la etiqueta de apertura abreviada puede estar deshabilitado Decir "algunos no admiten uno u otro" es objetivamente incorrecto. –
Hay dos métodos para iniciar PHP
<?php
y
<?
PHP también incluye
<?=
Pero eso va a imprimir la variable detrás es una forma abreviada de eco.
Debe usar <? Php ya que es compatible con todos los tipos de servidores. Puede mover su código a una nueva solución de alojamiento o configurar un nuevo servidor predeterminado y las manos cortas podrían estar deshabilitadas.
Las etiquetas cortas <?
(y <?=
) podrían estar deshabilitadas. La versión larga <?php
(y <?=
= <?php echo
) funciona en todas partes.
Podríamos discutir el sentido de esta decisión del equipo de PHP para hacer que tal cosa se pueda configurar, pero la esencia es que no se pueden usar las etiquetas cortas en el código portátil.
¿Por qué alguien podría desactivar las etiquetas cortas? –
@Orion Edwards: es una opción de configuración. php.ini hace que sea realmente difícil escribir código portátil. Más difícil de lo necesario. Si es una opción, entonces es un tabú para el código portátil. :-( – stesch
Wordpress Coding Standards dice only use <?php
. No explican por qué.
Esto podría ser una pregunta religiosa.
Php hace que el código sea más portátil, por eso lo recomiendo WordPress Coding Standards. – nickohrn
No creo que Stack Overflow tuviera comentarios cuando di esta respuesta. –
yo personalmente prefiero <?
a ser apagado por dos razones
- PHP estándares de codificación a través de muchos proyectos grandes PHP recomendaría a desconectable
- crea problemas si va a generar documentos XML (docs XML comienzan con
<?xml version="1.0" encoding="UTF-8" ?>
) - (bonus)
<?php
es más fácil de leer y visible que<?
.
# 3 es una característica MIS. Quiero que PHP se salga de mi maldita manera, no hacerse visible de manera prominente –
Su punto 2 lo convierte en un bozo: http://hsivonen.iki.fi/producing-xml/ – stesch
el apoyo de la forma corta <?
/<?=
sintaxis se basa en el short_open_tag
parameter in php.ini. Si aloja su propia base de código, es trivial para habilitar.Sin embargo, en un host web compartido/administrado, es posible que no tenga control sobre esta configuración.
Por lo tanto, para una máxima portabilidad, debe usar la sintaxis de forma larga.
Para agregar a la explicación de todos que las etiquetas cortas no deberían usarse porque podrían estar deshabilitadas (o incluso eliminadas de futuras versiones de PHP), la razón principal para que las etiquetas cortas queden obsoletas es que no son XML válidas. instrucciones "mientras que las etiquetas <?php
son. Por lo tanto, las plantillas PHP con etiquetas <?php ... ?>
pueden ser documentos XML válidos, mientras que las que usan etiquetas cortas no lo son.
Los argumentos de portabilidad son todos muy bien, pero yo voy a ser un sacrilegio y dicen que hay que seguir adelante y utilizar las etiquetas cortas si se quiere, a menos que esté haciendo algo que es para una distribución realmente amplia (de la fuente), o están enfocando algo muy xml.
a) Nunca he estado en una situación en la que no haya podido habilitar las etiquetas cortas. Usualmente están encendidos por defecto.
b) En la mayoría de las situaciones, el <?
no se confundirá con <?xml
porque están siendo analizados en diferentes niveles de la pila.
c) la etiqueta corta es menos obstructiva y por lo tanto desordena su código menos. Encuentro esto especialmente cierto con <?php echo
contra <?=
. (Podría argumentar que generalmente debería evitar usar cualquiera de esos, porque probablemente significa que está escribiendo código de espagueti, pero vamos, ¡esto es php!)
Por supuesto, todo depende de qué tipo de proyecto en el que está trabajando, pero para un sitio web básico, no creo que la etiqueta corta pueda dañarlo.
Sin embargo, en el futuro, las etiquetas cortas PHP no estarán habilitadas y todo su código se romperá con la próxima versión principal. –
¿Es eso verdad? ¿Hay una fuente oficial para eso? – sprugman
En php.net, veo una recomendación para usar etiquetas largas, lo cual está bien, pero no veo nada oficial sobre etiquetas cortas que desaparezcan. – sprugman
- 1. En PHP, ¿qué representa "<<<"?
- 2. Php ¿qué significa <<<?
- 3. expresión PHP <<< EOB
- 4. Escapando literalmente <? Php y <? en un script PHP
- 5. PHP usando Gettext dentro de <<< string EOF
- 6. ¿Por qué es "<?" ya no funciona y en su lugar solo funciona "<? php"?
- 7. Diferencia entre <? Php y <?
- 8. <? o <? php --- ¿hay alguna diferencia?
- 9. Php <? etiquetas en WAMP
- 10. PHP permitirá <?= ?>
- 11. ¿Qué significa '<? =' En PHP?
- 12. Accediendo a la variable definida dentro de <<< HTML en php
- 13. ¿Cuál es el uso de <<< EOD en PHP?
- 14. Operador de PHP <>
- 15. ¿Por qué debería usar <ARGV> o <> en lugar de <STDIN> en Perl?
- 16. Hacer un <br> en lugar de <div></div> pulsando Enter en un contenteditable
- 17. qué colección de C# usar en lugar de List <KeyValuePair <string, double >>?
- 18. ¿Hay alguna ventaja de usar '<< 1' en lugar de '* 2'?
- 19. ¿Cuándo utilizaría List <KeyValuePair <T1, T2>> en lugar de Dictionary <T1, T2>?
- 20. ¿Podemos forzar que XmlWriter emita <my-tag></my-tag> en lugar de <my-tag/>?
- 21. PHP error línea 1: `<?php ?> '
- 22. Lista <T> Ordenar utiliza Comparer <T> en lugar de IEquatable, ¿Por qué?
- 23. ¿por qué std :: string s ("?? <") generaba un {en lugar de ?? <como se esperaba?
- 24. ¿Es válido incluir imágenes con <object> en lugar de <img>?
- 25. ¿Puede button_to generar <button> etiqueta en lugar de <input type = "submit" />?
- 26. ¿Por qué Func <T,bool> en lugar de Predicado <T>?
- 27. <: <operador en scala
- 28. php: reemplazar el doble <br /> con</p><p>
- 29. Encontrar un pícaro <!----> en PHP
- 30. ¿Qué significa este símbolo en PHP <? =
Esto es esencialmente una estafa de http://stackoverflow.com/questions/436688/difference-between-php-echo-sessionid-and-sessionid –
no realmente; esa pregunta es sobre las etiquetas cortas (una forma rápida de hacer eco de los contenidos variables), ya que se trata de las diferentes convenciones de etiquetas. –
Pero las respuestas hacen que esto sea un engaño. –