在我的 jquery select2 搜索选项中没有出现

Posted

技术标签:

【中文标题】在我的 jquery select2 搜索选项中没有出现【英文标题】:In my jquery select2 search option isnt appearing 【发布时间】:2020-12-17 01:11:39 【问题描述】:

我在模态中使用 Jquery select2()。我已经包含了页面从中获取布局的链接 int 布局文件

<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/css/select2.min.css" 
rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/js/select2.min.js"></script>

我的模态代码在这里:

<div class="modal-body">
                <select class="js-example-basic-single button3" name="state">
                    @foreach($brands??array() as $brand)
                        <option>
                            <div role="listitem" class="quicklinks__item quicklinks__item--nav w-dyn-item" style="width: 300px;">
                                <a id="Nav-Quicklink" href="/vehicles?brand= $brand->slug "
                                    class="quicklinks__link w-inline-block"><img
                                            src="url($brand->photo??'')"
                                             class="quicklinks__logo" />
                                    <div class="quicklinks__details">
                                        <div class="quicklinks__title"> $brand->name </div>
                                    </div>
                                </a>
                            </div>
                        </option>
                    @endforeach
                </select>
            </div>

在这个文件中,我在脚本标签中添加了 jquery:

<script>
    $(document).ready(function() 
        $('.js-example-basic-single').select2();
    );
</script>

但是搜索框没有出现。仅显示选择列表。

出了什么问题?我怎样才能得到搜索框? TIA。 文件是here

【问题讨论】:

【参考方案1】:

看起来 select2 未应用于您的代码。你导入 jQuery 了吗?

添加

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.js"></script>

上面

<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/js/select2.min.js"></script>

【讨论】:

是的。其在 select2.min.js 上方的布局文件中导入 你可以在这里看到它github.com/yasirarafat28/Royaltyexoticcars/blob/master/… 你检查控制台输出了吗?也许有一些错误并指导我们。 控制台引用未捕获的类型错误:$(...).select2 不是函数。但我在布局文件中包含了链接 你可以尝试将 select2 js 文件移动到 【参考方案2】:

删除这个库

<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/css/select2.min.css" 
rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-beta.1/dist/js/select2.min.js"></script>

并用这个库替换

<link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.4/css/select2.min.css'><link rel="stylesheet">
<script src='https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.4/js/select2.min.js' defer></script>

如果仍然不起作用,请尝试在声明 select2 时替换 ID 而不是 class

下拉菜单

<div class="modal-body">
                <select class="js-example-basic-single button3" name="state" id="test">
                    @foreach($brands??array() as $brand)
                        <option>
                            <div role="listitem" class="quicklinks__item quicklinks__item--nav w-dyn-item" style="width: 300px;">
                                <a id="Nav-Quicklink" href="/vehicles?brand= $brand->slug "
                                    class="quicklinks__link w-inline-block"><img
                                            src="url($brand->photo??'')"
                                             class="quicklinks__logo" />
                                    <div class="quicklinks__details">
                                        <div class="quicklinks__title"> $brand->name </div>
                                    </div>
                                </a>
                            </div>
                        </option>
                    @endforeach
                </select>
            </div>

脚本

$(document).ready(function()
$("#test").select2();   
);

PS:确保脚本在表单内(关闭标记之前)!!!

【讨论】:

你可以在这里查看github.com/yasirarafat28/Royaltyexoticcars/blob/master/… 文件不大 @NabidAnzum 你试过用 id 替换类吗? 是的,我做到了。 @史蒂文94 控制台指的是Uncaught TypeError: $(...).select2 is not a function

以上是关于在我的 jquery select2 搜索选项中没有出现的主要内容,如果未能解决你的问题,请参考以下文章

JQuery Select2 不会更改选定的 html 选项

jquery select2 - 不工作

搜索时的Jquery select2自定义javascript函数

select2 gem 在搜索后记住选择的选项

如何在JQuery数据库CellEdit上集成Select2插件?

无法从 select2 搜索结果中选择结果