从2columns-right.phtml中的以下行开始
<div class="col-main">
<?php echo $this->getChildHtml('global_messages') ?>
<?php echo $this->getChildHtml('content') ?>
</div>
Run Code Online (Sandbox Code Playgroud)
我无法理解,从哪里来的内容<?php echo $this->getChildHtml('content') ?>.
调用witch .phtml文件来显示数据 <?php echo $this->getChildHtml('content') ?>
Dar*_*ton 151
如果我们正在讨论网站的前端,那么您询问的特定线路......
<?php echo $this->getChildHtml('content') ?>
Run Code Online (Sandbox Code Playgroud)
被添加到app/design/frontend/base/default/layout/page.xml中的Magento布局XML中.在Magento 1.8版中,您将在第92-94行中找到它.
<block type="core/text_list" name="content" as="content" translate="label">
<label>Main Content Area</label>
</block>
Run Code Online (Sandbox Code Playgroud)
通过查看此块标记的"type"属性,我们可以知道布局的这一部分是什么对象类.它来自"核心"模块,属于块类型文本列表.此Mage_Core_Block_Text_List的类名.(应用程序/代码/核心/法师/核心/砌块/文本/ list.php的).文本列表只是块容器,其目的是在其中存储其他子块.您可以在文本列表中添加任意数量的子块,它们将按照添加顺序或已分配的顺序呈现出来.
因此,要回答您的问题,没有视图脚本(.phtml文件)呈现$ this-> getChildHtml('content')的内容.已添加到此块的块本身可能具有与其关联的视图脚本.要找出那些视图脚本,您必须找到添加了块的布局XML.
例如,如果我将以下布局文件添加到我网站主题的前端:
<?xml version="1.0"?>
<layout>
<default>
<reference name="content">
<block type="core/template" name="my_view_script" template="hello/world.phtml" />
</reference>
</default>
</layout>
Run Code Online (Sandbox Code Playgroud)
上面的代码,将带有对象类Mage_Core_Block_Template的块添加到名为'content'的块中(恰好是您询问的那个).然后,Magento将按以下顺序在以下位置查找视图脚本:
app/design/frontend/PACKAGE_NAME/THEME_NAME/template/hello/world.phtml
app/design/frontend/PACKAGE_NAME/default/template/hello/world.phtml
app/design/frontend/base/default/template/hello/world.phtml
Run Code Online (Sandbox Code Playgroud)
找到的第一个是它将使用的那个.如果未找到视图脚本,Magento将在var/logs/system.log(默认日志文件设置)中记录错误,指出未找到视图脚本.不会发生块的输出.
请注意,根据您在系统 - >配置 - >(常规)设计中的设置,可能会有其他package/theme位置Magento将查看.还有其他方案,例如是否为各个CMS页面更改了"自定义主题"字段,目录类别或目录产品,这些单个模型的视图页面可能具有优先于您站点的默认设置的附加视图脚本位置(将与所选主题匹配).
在查找翻译文件以及布局XML文件时,Magento将遵循相同的回退逻辑.
请注意,复制单个视图脚本(避免复制整个目录,仅复制您实际打算修改的视图脚本)app/design/frontend/base/default/template/到本地主题完全可以接受,并根据您网站的主题自定义它们.但是,为了使升级兼容的站点,不应将布局文件从基本复制到本地主题.这样做,不遵循升级兼容的做法.相反,您的主题的XML布局更新应包含在app/design/frontend/PACKAGE_NAME/THEME_NAME/layout/local.xml.没有布局指令app/design/frontend/base/default/layout/*,无法使用local.xml中的正确XML指令删除/添加/更改,有什么用.