Як здійснити простий дзвінок ajax в Magento 2.1.0


11

Я додав просту кнопку в один із моїх файлів phtml.

<input type='button' name='emq_zip_btn' class='emq_zip_btn' value='Go'>

Я додав один спеціальний js-файл ("emq.js") із спеціального модуля (Ved_Mymodule):

require([
    "jquery",
    "jquery/ui"
], function($v){
//<![CDATA[
    $v = jQuery.noConflict();
    $v(document).ready(function() 
    {
        console.log('jquery loaded from emq.js');
        $v(".emq_zip_btn").on('click',function(e)
        {
            console.log('clicked');
        });
    });
//]]>
});

Коли я натискаю на вищезгадану кнопку, тоді на консолі друкується "натиснута", тобто jQuery працює належним чином.

Ось файл контролера з користувацького модуля Ved_Mymodule:

Ved \ Mymodule \ Controller \ Index \ Index.php:

<?php

namespace Ved\Mymodule\Controller\Index;

use Ved\Mymodule\Model\NewsFactory;
use Magento\Framework\App\Action\Action;
use Magento\Framework\App\Action\Context;

class Index extends Action
{
    /**
     * @var \Tutorial\SimpleNews\Model\NewsFactory
     */
    protected $_modelNewsFactory;

    /**
     * @param Context $context
     * @param NewsFactory $modelNewsFactory
     */
    public function __construct(
        Context $context,
        NewsFactory $modelNewsFactory
    ) {
        parent::__construct($context);
        $this->_modelNewsFactory = $modelNewsFactory;
    }

    public function execute()
    {

    }
}

Ved / Mymodule / тощо / frontend / routes.xml:

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:noNamespaceSchemaLocation="../../../../../../lib/internal/Magento/Framework/
App/etc/routes.xsd">
    <router id="standard">
        <route id="news" frontName="news">
            <module name="Ved_Mymodule" />
        </route>
    </router>

Моє запитання - як повернути дані з цього методу контролера, а потім отримати доступ до нього через jQuery, тобто як зробити простий дзвінок ajax після натискання на цю кнопку.


в'їду могли б ви пояснити мотику я повинен додати cuctom прапорець на деталі продукту page.when перевірив Я хочу , щоб додати $ 0,50 в ціні prodct які отримують оновлення в кошик , щоб
Ashwini

Відповіді:


19

нижче є приклад того, як це зробити. Будь ласка, змініть його відповідно до вашої вимоги.

Я використовував для цього шаблон js.

Наступний приклад створить спадний файл у вашому файлі phtml за допомогою функцій ajax.

У вашому JS

define([
        'jquery',
        'underscore',
        'mage/template',
        'jquery/list-filter'
        ], function (
            $,
            _,
            template
        ) {
            function main(config, element) {
                var $element = $(element);
var YOUR_URL_HERE = config.AjaxUrl;
                $(document).on('click','yourID_Or_Class',function() {
                        var param = 'ajax=1';
                            $.ajax({
                                showLoader: true,
                                url: YOUR_URL_HERE,
                                data: param,
                                type: "POST",
                                dataType: 'json'
                            }).done(function (data) {
                                $('#test').removeClass('hideme');
                                var html = template('#test', {posts:data}); 
                                $('#test').html(html);
                            });
                    });
            };
        return main;
    });

У контролері

public function __construct(
        Context $context,
        \Magento\Framework\Controller\Result\JsonFactory $resultJsonFactory
    ) {

        $this->resultJsonFactory = $resultJsonFactory;
        parent::__construct($context);
    }


    public function execute()
    {
        $result = $this->resultJsonFactory->create();
        if ($this->getRequest()->isAjax()) 
        {
            $test=Array
            (
                'Firstname' => 'What is your firstname',
                'Email' => 'What is your emailId',
                'Lastname' => 'What is your lastname',
                'Country' => 'Your Country'
            );
            return $result->setData($test);
        }
    }

У вашому файлі phtml

<style>  
.hideme{display:none;}
</style>
<script type="text/x-magento-init">
        {
            "*": {
                "[Namespace]_[Modulename]/js/YOURFILE": {
                    "AjaxUrl": "<?php echo $block->getAjaxUrl(); ?>",
                }
            }
        }
</script>
<div id='test' class="hideme">
    <select>
      <% _.each(posts, function(text,value) { %>
         <option value="<%= value %>"><%= text %></option>
      <% }) %> 
     </select>
</div>

getAjaxUrl повинна бути функцією у вашому блоковому файлі, яка повертає вам URL-адресу

Сподіваюся, що це допомагає.


Спасибі за вашу відповідь. Чи можете ви сказати мені, що я повинен зазначити у параметрі url методу $ .ajax. FrontName мого контролера - новини.
вiд

modulefrontname / index / news thsi буде працювати, якщо шлях вашого контролера є [простір імен] / [ім'я модуля] /Controller/Index/News.php, я вважаю за краще передавати URL з файлу шаблону, який створює URL з блоку за допомогою $ this-> getUrl
Ekta Пурі

так, в magento 1, я також передав URL лише з файлу шаблону. але в magento 2 код jquery у файлі шаблону не працює.
вiд

Я оновив свою відповідь, вона містить код у файлі phtml, щоб завантажити js, але ваш js має бути в папці вашого модуля
Ekta Puri

Ви можете отримати доступ до URL в js, скориставшись config.AjaxUrl
Ekta Puri
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.