Usted realmente no debería hacer esto, pero si que sea absolutamente necesario, puede hacerlo mediante el uso de esta clase:
class PhpStringParser
{
protected $variables;
public function __construct($variables = array())
{
$this->variables = $variables;
}
protected function eval_block($matches)
{
if(is_array($this->variables) && count($this->variables))
{
foreach($this->variables as $var_name => $var_value)
{
$$var_name = $var_value;
}
}
$eval_end = '';
if($matches[1] == '<?=' || $matches[1] == '<?php=')
{
if($matches[2][count($matches[2]-1)] !== ';')
{
$eval_end = ';';
}
}
$return_block = '';
eval('$return_block = ' . $matches[2] . $eval_end);
return $return_block;
}
public function parse($string)
{
return preg_replace_callback('/(\<\?=|\<\?php=|\<\?php)(.*?)\?\>/', array(&$this, 'eval_block'), $string);
}
}
Llámelo como esto:
$p = new PhpStringParser();
echo $p->parse($string);
Fuente: http://www.php.net/manual/en/function.eval.php#108091
sí mantienen presentación y la lógica separada. Tener que hacer esto indicaría que es posible que desee replantear sus elecciones de diseño. – dm03514
Por la forma en que está estructurando su sitio, puedo decirle ahora que esto causará problemas en el futuro. Aquí está mi sugerencia: use Smarty, o similar, para separar plantillas y códigos. – Hassan
Parece que ha tomado una decisión de diseño realmente ** realmente ** mala. – PeeHaa