Rufen Sie den statischen Block in der Datei view.phtml auf


14

Auf der Ansichtsseite wird ein Textfeld angezeigt, um die Verfügbarkeit von Nachnahme zu überprüfen.

Bildbeschreibung hier eingeben

view.phtml

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

In view.phtmlder folgenden Datei rufen wir auf. Aber ich möchte statische Blockkennung [Identifier Code - Check] anstelle der folgenden Datei aufrufen .

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>

statischer Blockcode:

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

Antworten:


44

Sie können den folgenden Code verwenden:

in der .phtml Datei:

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

Stichprobe :

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

in statischem Block / cms Seite:

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


Es wird jetzt kein Textfeld angezeigt. Ich habe den fraglichen statischen Blockcode aktualisiert.
Baby in Magento

Hast du deinen Cache aktualisiert?
Qaisar Satti

ja Cache-Ordner gelöscht, auch Browser-Cache entfernt.
Baby in Magento

1
{{block type ="core/template" template="checkdelivery/checkdelivery.phtml" }}Leerzeichen entfernen und die system->permission ->blockListe überprüfen (Core / Template)?
Qaisar Satti

1
createBlock ('Magento \ Cms \ Block \ Block') statt -> createBlock ('cms / block') hat für mich geschrieben :) Danke für diesen Tipp!
Rustyjim

3

Wenn Sie einen CMS-Block mit dem Namen "block_identifier" im Admin-Bereich erstellt haben. Dann folgt Code, um sie in .phtml aufzurufen

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

Cache leeren und Browser neu laden.

Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.