将Select2与Magento 2集成

问题描述 投票:5回答:2

我正在尝试将Select2与Magento2集成。到目前为止,我已经成功集成了插件,但是控制台上显示错误。enter image description here

我做了什么:

  1. 下载了select2.min.js并将其放入app/design/frontend/<vendor>/<themename>/web/js/select2.min.js
  2. [app/design/frontend/<vendor>/<themename>/Magento_Theme/layout/default_head_blocks.xml中包含脚本
  3. 将其添加到脚本标记中的phtml文件中:

    require(['jquery'],function(jquery){ jquery(document).load(function() { jquery("#sorter2").select2(); }); });

我知道我应该通过requireJS包含它,但是我似乎无法使其工作。

谢谢!

requirejs magento2 select2
2个回答
4
投票

您不应该将其添加到每个页面的标题中,因为不一定会加载依赖项。您需要在此处将其添加到主题requirejs-config中;

/app/design/frontend/<vendor>/<theme>/requirejs-config.js

在文件中放入这个;

var config = {
    paths: {
        'select2': 'js/select2.min',
    },
};

现在在任何phtml文件中,您都可以这样称呼;

<script type="text/javascript">
    require(['jquery','select2'],function($){
        // do stuff with select
    });
</script>

0
投票

类似这样的工作:

requirejs-config.js

var config = {
    paths: {
        'select2': 'SATA_SparePartsFinder/js/vendor/select2.full'
    }
};

在您的.phtml中:

<script type="text/javascript">
    require(['jquery', 'select2'], function($) {
        $('#model-select').select2({language: {
                noResults: function () {
                    return '<?= __('No results found') ?>';
                }
            }});
    });
</script>
© www.soinside.com 2019 - 2024. All rights reserved.