laravel框架select2多选插件初始化默认选中项操作示例


Posted in PHP onFebruary 18, 2020

本文实例讲述了laravel框架select2多选插件初始化默认选中项操作。分享给大家供大家参考,具体如下:

项目中有发送消息功能,需要能通过搜索,多选用户,来指定发送人。使用 select2 插件来完成。

select2 的 html 代码如下:

<div class="form-group" id="member_group">
  <label class="col-lg-3 control-label required">选择用户
  <span class="required">*</span>
  </label>
  <div class="col-lg-4">
  <select class="form-control" name="user_id[]" id="member_select" multiple="multiple"></select>
  </div>
</div>

select2 的 js 代码如下:

//选择用户
$("#member_select").select2({
  ajax: {
    //请求的URL
    url: "{{ route('member.index') }}",
    //返回的数据类型
    dataType: "json",
    //延迟时间,毫秒
    delay: 500,
    //是否缓存
    cache: true,
    //查询数据
    data: function (params) {
      //params.term就是你搜索输入的参数
      return {
        search: params.term,
        page: params.page || 1
      };
    },
    //请求结果回调函数,data就是后端返回的数据
    processResults: function (data, params) {
      var data = data.data;
      var results = [];
      //循环数据,将数据压入results中
      //注意数据必须要有二个属性,id和text,分别对应option的value和文本
      //网上有些说无法选中元素,请先检查这里,你是否设置了id,并且不为空
      $(data.data).each(function (i, obj) {
        results.push({
          id: obj.id,
          text: obj.name
        });
      });
      return {
        results: results,
        pagination: {
          more: (data.current_page * data.per_page) < data.total
        }
      };
    }
  },
  placeholder: '选择用户',
  //是否多选
  multiple: true,
  allowClear: true
});

后端返回的数据如下,直接使用 laravel 的 paginate() 方法 返回分页数据。

{
  "status_code":200,
  "message":"查询成功",
  "data":{
    "current_page":1,
    "data":[
      {
        "id":2006,
        "name":"用户1"
      },
      {
        "id":2005,
        "name":"用户3"
      },
      {
        "id":2004,
        "name":"用户3"
      }
    ],
    "first_page_url":"http://test.me/member/index?page=1",
    "from":1,
    "last_page":1,
    "last_page_url":"http://test.me/member/index?page=1",
    "next_page_url":"http://test.me/member/index?page=1",
    "path":"http://test.me/member/index",
    "per_page":1,
    "prev_page_url":null,
    "to":null,
    "total":3
  }
}

在编辑消息时,我们需要查看,这条消息发送给了哪些人,这就需要进入编辑页面时,让 select2 默认选中用户。

网上说通过如下方法可以选中。

$("#spread_select").val([1, 2]).trigger("change");

但是我们这里select2的option是通过ajax动态加载的,刚进页面时,select2的ajax根本没有触发,导致select2中没有option元素,更无法被选中。

我们通过下面的方式,来实现默认选中。

var selObj = [
  {"id": 1, "name": "小徐"},
  {"id": 2, "name": "小张"},
  {"id": 3, "name": "小明"},
];
(function initSel(selObj) {
  if (selObj) {
    for (var ix = 0; ix < selObj.length; ix++) {
      var item = selObj[ix];
      var option = new Option(item.name, item.id, true, true);
      $("#member_select").append(option);
    }
    $("#member_select").trigger('change');
  }
})(selObj);

selObj中的数据,可以通过PHP后端生成好后,渲染到页面,然后通过JSON.parse()解析成JSON对象。

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

PHP 相关文章推荐
用PHP 快速生成 Flash 动画的方法
Mar 06 PHP
php不写闭合标签的好处
Mar 04 PHP
分享一段php获取linux服务器状态的代码
May 27 PHP
[原创]smarty简单模板变量输出方法
Jul 09 PHP
全面解析PHP验证码的实现原理 附php验证码小案例
Aug 17 PHP
PHP版微信第三方实现一键登录及获取用户信息的方法
Oct 14 PHP
iOS+PHP注册登录系统 PHP部分(上)
Dec 26 PHP
PHP最常用的正则表达式
Feb 13 PHP
PHP实现的登录页面信息提示功能示例
Jul 24 PHP
PHP 并发场景的几种解决方案
Jun 14 PHP
Yii框架核心组件类实例详解
Aug 06 PHP
PHP判断一个变量是否为整数、正整数的方法示例
Sep 11 PHP
laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作示例
Feb 18 #PHP
PHP For循环字母A-Z当超过26个字母时输出AA,AB,AC
Feb 16 #PHP
php反序列化长度变化尾部字符串逃逸(0CTF-2016-piapiapia)
Feb 15 #PHP
浅析PHP反序列化中过滤函数使用不当导致的对象注入问题
Feb 15 #PHP
php 函数中静态变量使用的问题实例分析
Mar 05 #PHP
php多进程中的阻塞与非阻塞操作实例分析
Mar 04 #PHP
php 中的信号处理操作实例详解
Mar 04 #PHP
You might like
php mssql 数据库分页SQL语句
2008/12/16 PHP
PHP读取xml方法介绍
2013/01/12 PHP
php自定义函数截取汉字长度
2014/05/15 PHP
javascript中巧用“闭包”实现程序的暂停执行功能
2007/04/04 Javascript
js 页面关闭前的出现提示的实现代码
2011/05/25 Javascript
js中设置元素class的三种方法小结
2011/08/28 Javascript
计算新浪Weibo消息长度(还可以输入119字)
2013/07/02 Javascript
JS定义回车事件(实现代码)
2013/07/08 Javascript
浅析JavaScript中的CSS属性及命名规范
2013/11/28 Javascript
Javasipt:操作radio标签详解
2013/12/30 Javascript
js去除输入框中所有的空格和禁止输入空格的方法
2014/06/09 Javascript
javascript实现的HashMap类代码
2014/06/27 Javascript
JavaScript中string对象
2015/06/12 Javascript
Angular Js文件上传之form-data
2015/08/28 Javascript
JS实现的驼峰式和连字符式转换功能分析
2016/12/21 Javascript
详解前端构建工具gulpjs的使用介绍及技巧
2017/01/19 Javascript
Windows安装Node.js报错:2503、2502的解决方法
2017/10/25 Javascript
Node.js readline模块与util模块的使用
2018/03/01 Javascript
详解webpack打包后如何调试的方法步骤
2018/11/07 Javascript
JavaScript实现图片上传并预览并提交ajax
2019/09/30 Javascript
webpack 最佳配置指北(推荐)
2020/01/07 Javascript
Python time模块详解(常用函数实例讲解,非常好)
2014/04/24 Python
Python Queue模块详解
2014/11/30 Python
Python的string模块中的Template类字符串模板用法
2016/06/27 Python
python操作xlsx文件的包openpyxl实例
2018/05/03 Python
python远程连接服务器MySQL数据库
2018/07/02 Python
python求加权平均值的实例(附纯python写法)
2019/08/22 Python
解决在pycharm运行代码,调用CMD窗口的命令运行显示乱码问题
2019/08/23 Python
html5 canvas 使用示例
2010/10/22 HTML / CSS
BRASTY捷克:购买香水、化妆品、手袋和手表
2017/07/12 全球购物
校庆接待方案
2014/03/18 职场文书
环境卫生倡议书
2014/08/29 职场文书
法定代表人资格证明书
2015/06/18 职场文书
2015年小学教科研工作总结
2015/07/20 职场文书
python opencv检测直线 cv2.HoughLinesP的实现
2021/06/18 Python
Redis Stream类型的使用详解
2021/11/11 Redis