chamar bloco estático em view.phtml instalado do arquivo phtml

14

estamos exibindo o campo de texto na página de visualização para verificar a disponibilidade do COD.

insira a descrição da imagem aqui

view.phtml

echo $this->getLayout()->createBlock('core/template')->setTemplate('checkdelivery/checkdelivery.phtml')->toHtml();

em view.phtmlque estamos chamando o arquivo abaixo. mas eu quero chamar o identificador de bloco estático [identifier code - check] em vez do arquivo abaixo.

template / checkdelivery / checkdelivery.phtml

<div class="block block-list block-check-delivery">
    <div class="block-title">
        <?php $blockLabel = Mage::getStoreConfig('checkdelivery/general/block_title'); ?>
        <strong><span><?php echo $this->__($blockLabel) ?></span></strong>
    </div>
    <div class="block-content" >        
        <br>
            <input name="zipcode" size="17" type="text" id="zipcode" value="<?php echo Mage::getModel('core/cookie')->get('zip'); ?>" maxlength="10" class="input-text" placeholder="<?php echo $this->__('Enter ZIP Code'); ?>"/>
            <button type="button" name="zip-check" title="Check" class="button" id="zip-check" ><span><?php echo $this->__('Check'); ?></span></button>
            <div id="delivery-message"></div>
            <?php $defaultHtml = Mage::getStoreConfig('checkdelivery/general/default_html'); ?>
            <div id="delivery-html"><?php if(Mage::getModel('core/cookie')->get('message')){
    echo Mage::getModel('core/cookie')->get('message');
}
else{
    $defaultHtml; } ?></div>

        <br>        
    </div>

</div>

<script>
    Event.observe('zip-check', 'click', function(event){
        new Ajax.Request("<?php echo $this->getUrl('checkdelivery/index/index') ?>", {
            method: "get",
            parameters: {zipcode : $('zipcode').value },
            onSuccess: function(transport) {
                 var json = transport.responseText.evalJSON();
                 $('delivery-message').update(json.message);                 
                 $('delivery-message').setStyle({ color: json.color});
                 $('delivery-html').update(json.html);  
            }
        });
    });
</script>

código de bloco estático:

<p>{{block type ="core/template" template = "checkdelivery/checkdelivery.phtml"}}</p>
Bebê em Magento
fonte

Respostas:

44

Você pode usar o código abaixo:

no arquivo .phtml:

<?php
  echo $this->getLayout()->createBlock('cms/block')->setBlockId('block_identifier')->toHtml(); 
?> 

amostra:

<?php echo $this->getLayout()->createBlock('cms/block')->setBlockId('home')->toHtml(); ?> 

na página estática do bloco / cms:

{{block type="core/template" template="checkdelivery/checkdelivery.phtml"}}

Qaisar Satti
fonte
não está exibindo o campo de texto agora. Eu atualizei o código de bloco estático em questão.
Bebê em Magento
você atualizou seu cache?
Qaisar Satti 29/04
pasta de cache excluída sim, também removeu o cache do navegador.
Bebê em Magento
1
{{block type ="core/template" template="checkdelivery/checkdelivery.phtml" }}remover espaço e verificar system->permission ->blockse está listado (modelo / núcleo)?
Qaisar Satti 29/04
1
createBlock ('Magento \ Cms \ Block \ Block') em vez de -> createBlock ('cms / block') escrito por mim :) Obrigado por esta dica!
Rustyjim
3

Se você criou o bloco CMS chamado 'block_identifier' no painel de administração. Em seguida, será apresentado o código para chamá-los em .phtml

<?php echo $this->getLayout()->createBlock('cms/block')->setBlockId('block_identifier')->toHtml(); 
?> 

Limpe o cache e recarregue seu navegador.

J.wiston
fonte