select2 超好用的下拉选单

Rails 自带的下拉选单不好用,效果一般,流行的 select2 就好用多了。

参考链接:

注意

从 Rails5.1 版本开始,Gemfile 默认不再安装 gem 'jquery-rails' ,无法正常使用 select2,解决方法如下:

Gemfile 加入 gem 'jquery-rails'

终端 bundle install

重启 rails s

修改文件 app/assets/javascripts/application.js

- //= require rails-ujs
+ //= require jquery
+ //= require jquery_ujs

select2 简单教程

Gemfile 加入 gem 'select2-rails'

终端 bundle install

重启 rails s

文件 app/assets/javascripts/application.js 最下方添加代码

//= require select2

文件 app/assets/stylesheets/application.scss 最下方添加代码

 @import "select2";
 @import "select2-bootstrap";

从 User 表中实现单选与多选(省略 User 表的相关建立)

  <%= form_for @letter_text do |f| %>
    <p>
      <%= f.label "收件人" %>
      <!-- 用户.多选框 -->
      <%= select_tag :rec_id, options_for_select(User.all.collect{|a| [a.name, a.id]}), class: "form-control" ,multiple: "true"%>
    </p>

    <p>
      <%= f.label "发件人" %>
      <!-- 用户.单选框 -->
      <%= select_tag :send_id, options_for_select(User.all.collect{|a| [a.name, a.id]}), class: "form-control"%>
    </p>

    ......#省略无关代码
  <% end %>
</div>

<script>
// 多选框样式
$("#rec_id").select2({
    theme: "bootstrap"
})
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Bootstrap Select2是一个基于jQuery的自定义下拉选择插件,可以让用户在一个优雅的界面中选择数据。 树形下拉是Bootstrap Select2的一个特殊功能,它允许我们将数据以树形结构展示在下拉框中,方便用户快速选择和搜索。 使用Bootstrap Select2树形下拉,首先需要引入Select2的库文件和相关样式。然后在HTML中创建一个下拉菜单的元素,并为其添加一个自定义的class。接下来,需要通过JavaScript来配置Select2插件。 配置Select2的时候,我们需要同时传入数据源以及一些额外的配置选项。对于树形下拉的数据源,我们可以使用一个以JSON对象的形式表示的树状结构。 例如,下面是一个简单的JSON对象,表示一个带有"节点1"和"节点2"的树形结构: { "id": 1, "text": "节点1", "children": [ { "id": 2, "text": "节点2" } ] } 在配置Select2的时候,我们可以用ajax方法获取这个JSON数据,并将其传入"data"选项中。 除了数据源外,我们还可以通过配置选项调整下拉框的外观和功能。例如,可以启用搜索功能,使用户能够在下拉框中快速查找节点。 最后,我们需要通过JavaScript来初始化Select2插件并将其应用到我们创建的下拉菜单元素上。 在使用过程中,用户可以通过点击下拉框,展开或折叠树形结构。他们可以通过输入关键字来搜索节点,并选择他们想要的节点。 总结起来,Bootstrap Select2树形下拉是一个强大的工具,可以方便地在界面上展示和搜索树状数据。这个功能可以通过合适的JSON数据源和一些配置选项来实现。同时,用户可以通过点击和搜索来选择他们想要的节点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值