मैं Magento 2 में AJAX के माध्यम से HTML रेंडर करने का सबसे अच्छा तरीका खोजने की कोशिश करता हूं।
तरीका 1: बिना लेआउट के कंट्रोलर का उपयोग करना
फ़ाइल Foo/Bar/Controller/Popin/Content.php
<?php
namespace Foo\Bar\Controller\Popin;
use Magento\Framework\App\Action\Action;
use Magento\Framework\App\Action\Context;
/**
* Class Content
*/
class Content extends Action
{
/**
* Content constructor.
*
* @param Context $context
*/
public function __construct(
Context $context
) {
parent::__construct($context);
}
/**
*
*/
public function execute()
{
/** @var \Magento\Framework\View\Layout $layout */
$layout = $this->_view->getLayout();
/** @var \Foo\Bar\Block\Popin\Content $block */
$block = $layout->createBlock(\Foo\Bar\Block\Popin\Content::class);
$block->setTemplate('Foo_Bar::popin/content.phtml');
$this->getResponse()->setBody($block->toHtml());
}
}
रास्ता 2: कस्टम लेआउट के साथ नियंत्रक का उपयोग करना
फ़ाइल Foo/Bar/Controller/Popin/Content.php
<?php
namespace Foo\Bar\Controller\Popin;
use Magento\Framework\App\Action\Action;
use Magento\Framework\App\Action\Context;
/**
* Class Content
*/
class Content extends Action
{
/**
* Content constructor.
*
* @param Context $context
*/
public function __construct(
Context $context
) {
parent::__construct($context);
}
/**
*
*/
public function execute()
{
$this->_view->loadLayout();
$this->_view->renderLayout();
}
}
फ़ाइल Foo/Bar/view/frontend/page_layout/ajax-empty.xml
<?xml version="1.0"?>
<layout xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/page_layout.xsd">
<container name="root"/>
</layout>
फ़ाइल Foo/Bar/view/frontend/layout/foo_bar_popin_content.xml
<?xml version="1.0"?>
<page xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" layout="ajax-empty" xsi:noNamespaceSchemaLocation="urn:magento:framework:View/Layout/etc/page_configuration.xsd">
<body>
<referenceContainer name="root">
<block class="Foo\Bar\Block\Popin\Content" name="foo_bar_popin_content" template="Foo_Bar::popin/content.phtml" cacheable="false"/>
</referenceContainer>
</body>
</page>
IMO सबसे अच्छा अभ्यास तरीका 2 लगता है क्योंकि यह नियंत्रक से तर्क को अलग करता है।
लेकिन साथ इस मुद्दे रास्ता 2 कि है <body>
और <head>
साथ CSS
/ JS
उत्पन्न कर रहे हैं तो यह उस में केवल मेरे ब्लॉक टेम्पलेट के साथ एक पूर्ण साफ एचटीएमएल नहीं है।
- क्या मैं गलत तरीके से कस्टम लेआउट का उपयोग कर रहा हूं?
- क्या रास्ता 1 को एक अच्छा अभ्यास माना जाता है?
- क्या ऐसा करने के कोई और तरीके हैं?