从 jQuery 创建选项时,在 select2 中添加一个空选项

Posted

技术标签:

【中文标题】从 jQuery 创建选项时,在 select2 中添加一个空选项【英文标题】:Add an empty option in select2 when options are created from jQuery 【发布时间】:2022-01-16 20:29:32 【问题描述】:

当我从jQuery 设置选项时,我尝试添加一个空的<option></option>,但在加载页面时选择了第一个选项。我添加了allowClear: true, placeholder: "Select...",,但没有成功。

我找到了一个四处走走,在我初始化select2 后清除该选项,这可行但有更好的解决方案吗?

$(".select2-it").val(null).trigger('change');

var itData = [
    id: 0,
    text: 'Apps',
    children: [
        id: '1',
        text: 'App1'
      ,
      
        id: '2',
        text: 'App2'
      ,
      
        id: '3',
        text: 'App3'
      
    ]
  ,
  
    id: 4,
    text: 'bug'
  ,
  
    id: 5,
    text: 'duplicate'
  
];

$(".select2-it").select2(
  allowClear: true,
  placeholder: "Select...",
  data: itData,
  width: "100%"
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />

<select id="it-target" class="select2-it form-control"></select>

【问题讨论】:

为什么要添加一个空选项? 该选项在我的表单中是必需的,我希望用户选择一个值而不是第一个选项。 【参考方案1】:

您可以在对输入调用 Select2 初始化程序之前在 DOM 元素中添加空选项(使用 .prepend())。

var itData = [
    id: 0,
    text: 'Apps',
    children: [
         id: '1', text: 'App1' ,
         id: '2', text: 'App2' ,
         id: '3', text: 'App3' 
    ]
, 
    id: 4,
    text: 'bug'
, 
    id: 5,
    text: 'duplicate'
];

$(".select2-it").prepend('<option></option>').select2(
    allowClear: true,
    placeholder: "Select...",
    data: itData,
    width: "100%"
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />
<select id="it-target" class="select2-it form-control"></select>

【讨论】:

以上是关于从 jQuery 创建选项时,在 select2 中添加一个空选项的主要内容,如果未能解决你的问题,请参考以下文章

使用 Select2 jquery 进行多选的 ASP MVC 下拉列表

Select2 jquery插件在结果中显示所选项目的数量而不是标签

Jquery循环重复创建相同的对象

在 jquery UI 对话框上使用 select2 (v 4.0) 时,如何在使用远程数据源时让 allowClear 选项起作用?

Select2“全选”勾选从数据库表中获取选项的位置

当 Ajax 响应来自使用 select2 的 laravel 控制器时,如何检查 JQuery 附加选项中的条件?