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 相关文章推荐
海河写的 Discuz论坛帖子调用js的php代码
Aug 23 PHP
备份mysql数据库的php代码(一个表一个文件)
May 28 PHP
调试一段PHP程序时遇到的三个问题
Jan 17 PHP
使用php方法curl抓取AJAX异步内容思路分析及代码分享
Aug 25 PHP
php使用array_search函数实现数组查找的方法
Jun 12 PHP
分享PHP函数实现数字与文字分页代码
Jul 28 PHP
在WordPress中使用wp-cron插件来设置定时任务
Dec 10 PHP
YII使用url组件美化管理的方法
Dec 28 PHP
Swoole-1.7.22 版本已发布,修复PHP7相关问题
Dec 31 PHP
PHP实现QQ登录实例代码
Jan 14 PHP
php实现算术验证码功能
Dec 05 PHP
如何理解PHP核心特性命名空间
May 28 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适配器模式介绍
2012/08/14 PHP
深入php list()函数的详解
2013/06/05 PHP
phpmyadmin配置文件现在需要绝密的短密码(blowfish_secret)的2种解决方法
2014/05/07 PHP
学习php中的正则表达式
2014/08/17 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
PJ Blog修改-禁止复制的代码和方法
2006/10/25 Javascript
一个基于jquery的图片切换效果
2010/07/06 Javascript
ajax异步刷新实现更新数据库
2012/12/03 Javascript
点击隐藏页面左栏或右栏实现js代码
2013/04/01 Javascript
JavaScript动态改变表格单元格内容的方法
2015/03/30 Javascript
js获取微信版本号的方法
2015/05/12 Javascript
在Node.js中使用HTTP上传文件的方法
2015/06/23 Javascript
javascript实现继承的简单实例
2015/07/26 Javascript
基于js实现投票的实例代码
2015/08/04 Javascript
简单介绍JavaScript数据类型之隐式类型转换
2015/12/28 Javascript
Jil,高效的json序列化和反序列化库
2017/02/15 Javascript
解决Js先触发失去焦点事件再执行点击事件的问题
2018/08/30 Javascript
JS 遍历 json 和 JQuery 遍历json操作完整示例
2019/11/11 jQuery
JS Thunk 函数的含义和用法实例总结
2020/04/08 Javascript
es6函数之尾调用优化实例分析
2020/04/25 Javascript
Python使用scrapy采集数据过程中放回下载过大页面的方法
2015/04/08 Python
对于Python的框架中一些会话程序的管理
2015/04/20 Python
在Django的URLconf中使用命名组的方法
2015/07/18 Python
Python while 循环使用的简单实例
2016/06/08 Python
Python编程之基于概率论的分类方法:朴素贝叶斯
2017/11/11 Python
python随机取list中的元素方法
2018/04/08 Python
Python minidom模块用法示例【DOM写入和解析XML】
2019/03/25 Python
使用python socket分发大文件的实现方法
2019/07/08 Python
Python中的xlrd模块使用原理解析
2020/05/21 Python
通过实例解析Python RPC实现原理及方法
2020/07/07 Python
联想哥伦比亚网上商城:Lenovo Colombia
2017/01/10 全球购物
Linux如何为某个操作添加别名
2015/02/05 面试题
推荐信格式范文
2014/05/09 职场文书
儿童生日会策划方案
2014/05/15 职场文书
2015年部门工作总结范文
2015/03/31 职场文书
制定企业培训计划的五大要点!
2019/07/10 职场文书