Magento 2.1.0で単純なajax呼び出しを行う方法


10

私のphtmlファイルの1つに簡単なボタンを追加しました。

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

カスタムモジュール(Ved_Mymodule)から1つのカスタムjsファイル( "emq.js")を追加しました。

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');
        });
    });
//]]>
});

上記のボタンをクリックすると、「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 / etc / 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呼び出しを行う方法です。


vedu製品の詳細ページにcuctomチェックボックスを追加する必要がある場合に説明してください。チェックすると、カートに更新される製品価格に$ 0.50を追加します
Ashwini

回答:


17

以下は、これを行う方法の例です。要件に応じて変更してください。

これにはjsテンプレートを使用しました。

次の例では、ajax機能を使用してphtmlファイルにドロップダウンを作成します。

あなたの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を返すブロックファイル内の関数である必要があります。

お役に立てば幸いです。


お返事ありがとうございます。$ .ajaxメソッドのurlパラメーターで何を言及すればよいですか。私のコントローラーのfrontNameはニュースです。
vedu 2016

modulefrontname / index / news thsiは、コントローラーのパスが[namespace] / [modulename] /Controller/Index/News.phpの場合に機能します$ this-> getUrl
Ekta

はい、magento 1では、テンプレートファイルからのみURLも渡しました。しかし、magento 2では、テンプレートファイルのjqueryコードは機能しません。
vedu 2016

私は自分の答えを更新しましたが、jsをロードするためのコードがphtmlファイルにありますが、jsはモジュールフォルダーにあるはずです
Ekta Puri

あなたはconfig.AjaxUrlを使用してjsでURLにアクセスできます
Ekta Puri
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.