在PHP中,HEREDOC字符串声明对于输出html块非常有用.你可以通过在$前面加上变量来解析变量,但是对于更复杂的语法(比如$ var [2] [3]),你必须把你的表达式放在{}括号中.
在PHP 5中,这是可能实际上使函数调用中的{}一HEREDOC字符串中括号,但你必须要经过一些工作.函数名称本身必须存储在变量中,您必须将其称为动态命名函数.例如:
$fn = 'testfunction'; function testfunction() { return 'ok'; } $string = <<< heredoc plain text and now a function: {$fn()} heredoc;
正如你所看到的,这比仅仅更麻烦:
$string = <<< heredoc plain text and now a function: {testfunction()} heredoc;
除了第一个代码示例之外还有其他方法,例如突破HEREDOC来调用函数,或者反转问题并执行以下操作:
?> plain text and now a function:
后者的缺点是输出直接放入输出流(除非我使用输出缓冲),这可能不是我想要的.
所以,我的问题的实质是:有更优雅的方法来解决这个问题吗?
根据回复进行编辑:看起来某种模板引擎看起来确实会让我的生活变得更轻松,但这需要我基本上颠倒我常用的PHP风格.这不是一件坏事,但它解释了我的惯性......我想找出让生活变得更轻松的方法,所以我现在正在研究模板.
如果你真的想这样做,但比使用类更简单,你可以使用:
function fn($data) { return $data; } $fn = 'fn'; $my_string = <<
一个更紧凑的定义:`$ fn = function fn($ data){return $ data; };`
2> Peter Bailey..:亲自,我根本不会使用HEREDOC.它只是没有一个好的"模板构建"系统.您的所有HTML都被锁定在一个字符串中,该字符串有几个缺点
WYSIWYG没有选项
IDE中的HTML没有代码完成
输出(HTML)锁定到逻辑文件
你最终不得不像你现在想要做的那样使用hack来实现更复杂的模板,比如循环
得到一个基本的模板引擎,或者只是使用PHP与包括-这就是为什么语言具有
和
?>
分隔符.template_file.php
的index.php
Hello World!'; } include('template_file.php');
Short更好,更清洁,更容易阅读.在你的观点中`<?= $ title?>`比**更好**?php echo $ title; ?>.不利的是,对于分销来说,很多ini都有短标签.**但猜猜怎么了??从*PHP 5.4*开始,无论ini设置如何,都在PHP中启用了短标签!因此,如果您的编码要求为5.4+(例如,假设您正在使用特征),请继续使用那些非常棒的短标签!
echo有一个简写:`<?= $ valueToEcho;?>`或`<%= $ valueToEcho;%>`取决于你的INI设置.
我读到的关于使用这些短款的大多数内容都说使用它们是一种不好的做法,我同意.所以不幸的是,如果您正在编写用于分发的代码,则不能依赖于这些INI设置,从而使得PHP的"支持"对于分布式代码没有实际意义.FWIW,我不得不多次修复其他人的WordPress插件中的错误,因为他们使用了这些短信.
顺便说一下,即使关闭短标签,默认情况下也会在5.4中启用<?= $ blah?>.
3> 小智..:我会做以下事情:
$string = <<< heredoc plain text and now a function: %s heredoc; $string = sprintf($string, testfunction());不确定你是否认为这更优雅......
4> 小智..:试试这个(作为全局变量,或在需要时实例化):
现在任何函数调用都通过
$fn
实例.因此testfunction()
可以在heredoc中调用现有函数{$fn->testfunction()}
基本上我们将所有函数包装到类实例中,并使用PHP的
__call magic
方法将类方法映射到需要调用的实际函数.
当您不能仅将模板引擎添加到现有项目时,这是一个很好的解决方案.谢谢,我现在正在使用它.
5> BraedenP..:我有点迟了,但我随机发现了它.对于任何未来的读者,这是我可能会做的:
我只想使用输出缓冲区.基本上,你使用ob_start()启动缓冲,然后在其中包含你的"模板文件",包含任何函数,变量等,获取缓冲区的内容并将它们写入字符串,然后关闭缓冲区.然后,您已经使用了所需的任何变量,可以运行任何函数,并且您仍然可以在IDE中使用HTML语法高亮显示.
这就是我的意思:
模板文件:
脚本:
因此,脚本将template_file.php包含到其缓冲区中,运行任何函数/方法并在此过程中分配任何变量.然后,您只需将缓冲区的内容记录到变量中,然后使用它执行所需操作.
这样,如果你不想在那一秒就将它回显到页面上,你就不必这样做了.您可以在输出之前循环并继续添加到字符串.
如果您不想使用模板引擎,我认为这是最好的方法.
6> bishop..:为了完整性,您还可以使用
!${''}
黑魔法解析器黑客:echo <<
你去过霍格沃茨了吗?
@Starx哇花花公子,你刚刚完成了我的整个一周!:)
7> Michael McMi..:此片段将在userscope中定义具有已定义函数名称的变量,并将它们绑定到包含相同名称的字符串.让我来证明一下.
function add ($int) { return $int + 1; } $f=get_defined_functions();foreach($f[user]as$v){$$v=$v;} $string = <<< heredoc plain text and now a function: {$add(1)} heredoc;现在会工作.
8> 小智..:我认为使用heredoc非常适合生成HTML代码.例如,我发现以下几乎完全不可读.
但是,为了实现简单性,您必须在开始之前评估功能.我不相信这是一个如此可怕的约束,因为这样做,你最终将你的计算与显示分开,这通常是一个好主意.
我认为以下内容非常易读:
$page_content = getPageContent(); print <<$page_title $page_content END;不幸的是,尽管你提出了一个很好的建议,你将函数绑定到一个变量,最后,它增加了代码的复杂程度,这是不值得的,并使代码的可读性降低,这是heredoc的主要优点.
最近的4年证明,它比其他大多数方法都聪明得多。对于认真研究模板的人,在模板中使用合成(构建由较小页面组成的大页面)并使所有控制逻辑保持分离是标准方法:facebook的ReactJS在这方面(与XHP一样)非常出色,XSLT也是如此(我不爱,但是学术上不错。我要写的唯一的风格注释:我总是在变量周围使用{},主要是为了保持可读性并避免以后发生意外。另外,不要忘记对来自用户的任何数据进行htmlspecialchars()。
9> 小智..:在这里找到了包装功能很好的解决方案:http://blog.nazdrave.net/?p = 626
function heredoc($param) { // just return whatever has been passed to us return $param; } $heredoc = 'heredoc'; $string = <<