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 相关文章推荐
WindowsXP中快速配置Apache+PHP5+Mysql
Jun 05 PHP
php 文件缓存函数
Oct 08 PHP
基于php中使用excel的简单介绍
Aug 02 PHP
php json与xml序列化/反序列化
Oct 28 PHP
一个不易被发现的PHP后门代码解析
Jul 05 PHP
ThinkPHP字符串函数及常用函数汇总
Jul 18 PHP
php用ini_get获取php.ini里变量值的方法
Mar 04 PHP
php检索或者复制远程文件的方法
Mar 13 PHP
php给每个段落添加空格的方法
Mar 20 PHP
Laravel 5 框架入门(四)完结篇
Apr 09 PHP
strpos() 函数判断字符串中是否包含某字符串的方法
Jan 16 PHP
详解no input file specified 三种解决方法
Nov 29 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
laravel框架使用极光推送消息操作示例
Feb 15 #PHP
laravel框架使用阿里云短信发送消息操作示例
Feb 15 #PHP
laravel框架实现敏感词汇过滤功能示例
Feb 15 #PHP
You might like
php中在PDO中使用事务(Transaction)
2011/05/14 PHP
10个php函数实用却不常见
2015/10/13 PHP
JavaScript 学习笔记(四)
2009/12/31 Javascript
JavaScript 学习笔记一些小技巧
2010/03/28 Javascript
JS中引用百度地图并将百度地图的logo和信息去掉
2013/09/29 Javascript
Jquery获取元素的父容器对象示例代码
2014/02/10 Javascript
Jquery Uploadify上传带进度条的简单实例
2014/02/12 Javascript
使用JavaScript 编写简单计算器
2014/11/24 Javascript
js的for in循环和java里foreach循环的区别分析
2015/01/28 Javascript
网页禁用右键菜单和鼠标拖动选择方法小结
2015/02/25 Javascript
javascript数组去重方法分析
2016/12/15 Javascript
js记录点击某个按钮的次数-刷新次数为初始状态的实例
2017/02/15 Javascript
Vue 按键修饰符处理事件的方法
2018/05/04 Javascript
dts文件中删除一个node或属性的操作方法
2018/08/05 Javascript
使用vue-router与v-if实现tab切换遇到的问题及解决方法
2018/09/07 Javascript
微信小程序开发之点击按钮退出小程序的实现方法
2019/04/26 Javascript
详细教你微信公众号正文页SVG交互开发技巧
2019/07/25 Javascript
浅析Vue下的components模板使用及应用
2019/11/27 Javascript
JS禁用右键、禁用Ctrl+u、禁用Ctrl+s、禁用F12的实现代码
2020/12/01 Javascript
Python判断两个文件是否相同与两个文本进行相同项筛选的方法
2019/03/01 Python
Python多进程入门、分布式进程数据共享实例详解
2019/06/03 Python
Django生成PDF文档显示在网页上以及解决PDF中文显示乱码的问题
2019/07/04 Python
python2和python3哪个使用率高
2020/06/23 Python
h5网页水印SDK的实现代码示例
2019/02/19 HTML / CSS
马来西亚太阳镜、眼镜和隐形眼镜网上商店:Focus Point
2018/12/13 全球购物
财务学生的职业生涯发展
2014/02/11 职场文书
高中班主任评语大全
2014/04/25 职场文书
班主任评语大全
2014/04/26 职场文书
反腐倡廉警示教育活动总结
2014/05/05 职场文书
没有孩子的离婚协议书怎么写
2014/09/17 职场文书
离婚协议书范本2014
2014/10/27 职场文书
三峡导游词
2015/01/31 职场文书
医院志愿者活动总结
2015/05/06 职场文书
党员理论学习心得体会
2016/01/21 职场文书
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
2021/11/11 HTML / CSS
Pillow图像处理库安装及使用
2022/04/12 Python