亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 在Laravel中使用DataTables插件的方法

在Laravel中使用DataTables插件的方法

熱門標簽:拉薩打電話機器人 沈陽人工智能電銷機器人公司 寶安400電話辦理 智能外呼電銷系統 電銷機器人-快迭智能 合肥外呼系統app h5 地圖標注 高識別電銷機器人 哈爾濱400電話辦理到易號網

DataTables 是一個 jQuery 的表格插件,記錄一下在 Laravel 中使用的常用功能和用法,比如 ajax 獲取數據,自定義搜索,效果展現,選項說明等等,有一些細節記錄下來方便以后查看。

Laravel 控制器方法

接受 ajax get 請求,返回數據。

dataTables 會自帶一些參數過來,需要按照格式返回數據,比如分頁等。見 dataTables 官方文檔說明。

代碼如下:

// ajax GET 獲取列表數據
public function getList(Request $request)
{
  $dynamicType = $request->get('dynamic_type');
  $draw = $request->get('draw');
  $start = $request->get('start');
  $length = $request->get('length');
  $groupId = $request->get('group_id');
  $dynamicId = $request->get('dynamic_id');
  $userid = $request->get('userid');
  $isAudit = $request->get('is_audit', 0);

  if (!$dynamicType || !in_array($dynamicType, [1, 2])) {
    return response()->json(['error' => '缺少參數!']);
  }

  $builder = Dynamics::select(['id', 'userid', 'group_id', 'dynamic_id', 'dynamic_type', 'content', 'money', 'is_audit', 'audited_at'])->where('dynamic_type', $dynamicType);

  //自定義搜索
  if ($groupId) {
    $builder->where('group_id', $groupId);
  }

  if ($dynamicId) {
    $builder->where('dynamic_id', $dynamicId);
  }

  if ($userid) {
    $builder->where('userid', $userid);
  }

  if (!is_null($isAudit)) {
    $builder->where('is_audit', $isAudit);
  }

  $total = $builder->count();
  $list = $builder->orderBy('id', 'desc')->offset($start)->take($length)->get()->toArray();


  $imgInfo = [];
  $dynamicIds = $this->getDynamicIds($list);
  if ($dynamicIds) {
    $imgInfo = DynamicImage::whereIn('dynamic_id', $dynamicIds)->pluck('images', 'dynamic_id');
  }

  $fillImages = function ($item) use ($imgInfo) {
    if (isset($imgInfo[$item['dynamic_id']])) {
      $item["images"] = json_decode($imgInfo[$item['dynamic_id']]);
    } else {
      $item["images"] = [];
    }
    return $item;
  };
  $list = array_map($fillImages, $list);

  $data = [];
  $data["draw"] = $draw;
  $data["recordsTotal"] = $total;
  $data["recordsFiltered"] = $total;
  $data["data"] = $list;
  return response()->json($data);
}


// ajax GET 獲取列表數據
public function getList(Request $request)
{
  $dynamicType = $request->get('dynamic_type');
  $draw = $request->get('draw');
  $start = $request->get('start');
  $length = $request->get('length');
  $groupId = $request->get('group_id');
  $dynamicId = $request->get('dynamic_id');
  $userid = $request->get('userid');
  $isAudit = $request->get('is_audit', 0);
 
  if (!$dynamicType || !in_array($dynamicType, [1, 2])) {
    return response()->json(['error' => '缺少參數!']);
  }
 
  $builder = Dynamics::select(['id', 'userid', 'group_id', 'dynamic_id', 'dynamic_type', 'content', 'money', 'is_audit', 'audited_at'])->where('dynamic_type', $dynamicType);
 
  //自定義搜索
  if ($groupId) {
    $builder->where('group_id', $groupId);
  }
 
  if ($dynamicId) {
    $builder->where('dynamic_id', $dynamicId);
  }
 
  if ($userid) {
    $builder->where('userid', $userid);
  }
 
  if (!is_null($isAudit)) {
    $builder->where('is_audit', $isAudit);
  }
 
  $total = $builder->count();
  $list = $builder->orderBy('id', 'desc')->offset($start)->take($length)->get()->toArray();
 
 
  $imgInfo = [];
  $dynamicIds = $this->getDynamicIds($list);
  if ($dynamicIds) {
    $imgInfo = DynamicImage::whereIn('dynamic_id', $dynamicIds)->pluck('images', 'dynamic_id');
  }
 
  $fillImages = function ($item) use ($imgInfo) {
    if (isset($imgInfo[$item['dynamic_id']])) {
      $item["images"] = json_decode($imgInfo[$item['dynamic_id']]);
    } else {
      $item["images"] = [];
    }
    return $item;
  };
  $list = array_map($fillImages, $list);
 
  $data = [];
  $data["draw"] = $draw;
  $data["recordsTotal"] = $total;
  $data["recordsFiltered"] = $total;
  $data["data"] = $list;
  return response()->json($data);
}

dataTables 發 ajax 請求及一些選項設置

columnDefs 用來自定義每個字段如何展現,可以封裝自己的展現邏輯,也可以獲取到這一行各個字段的值。

createdRow 可以改變創建每一行的行為,比如修改這一行的樣式等等。

table.draw() 方法可以重新發起 ajax 請求。

script type="text/javascript">
  $dataTable = $("#dataTable");
  var table = $dataTable.DataTable({
    "processing": true,
    "serverSide": true,
    "pageLength": 25,
    "lengthMenu": [10, 25, 50, 75, 100, 200],
    "ajax": {
      "url": "{{ route('audit.getList') }}",
      "data": function (data) {
        data.dynamic_type = "{{ Request::get('dynamic_type', 1) }}";
        data.group_id = $("#group_id").val();
        data.dynamic_id = $("#dynamic_id").val();
        data.userid = $("#userid").val();
        data.is_audit = $("#is_audit").val();
        data.t = "{{ time() }}";
      }
    },
    "columns": [
      {"data": "id"},
      {"data": "userid"},
      {"data": "group_id"},
      {"data": "dynamic_type"},
      {"data": "dynamic_id"},
      {"data": "content"},
      {"data": "images"},
      {"data": "money"},
      {"data": "is_audit"},
      {"data": "audited_at"}
    ],
    "columnDefs": [
      {
        "render": function (data, type, row) {
          if (data == 1) {
            return "活動";
          } else if (data == 2) {
            return "動態";
          }
        },
        "targets": 3
      },
      {
        "render": function (data, type, row) {
          html = "";
          $.each(data, function (k, v) {
            html += "a href='" + v.origin + "' target='_blank'>img src='" + v.origin + "' width='160' style='margin-bottom: 2px;'>";
          });
          return html;
        },
        "targets": 6
      },
      {
        "render": function (data, type, row) {
          if (data == 0) {
            return "未審核";
          } else if (data == 1) {
            return "審核通過";
          } else if (data == -1) {
            return "審核不通過";
          }
        },
        "targets": 8
      },
      {
        "render": function (data, type, row) {
          if (row.is_audit == 0) {
            return "a class='btn btn-primary audit' data-type = 1>通過/a> a class='btn btn-danger audit' data-type = 2>不通過/a>";
          }
          return "-";
        },
        "targets": 10
      }
    ],
    "createdRow": function (row, data, index) {
      $('td', row).eq(4).attr('style', 'word-break:break-all');
      $('td', row).eq(2).attr('style', 'word-break:break-all');
      $('td', row).eq(5).attr('style', 'word-break:break-all');
    },
    "language": {
      processing: "數據加載中...",
      info: "顯示第 _START_ 至 _END_ 條,共 _TOTAL_ 條記錄",
      infoEmpty: "暫無數據",
      lengthMenu: "顯示 _MENU_ 條記錄",
      paginate: {
        first: "首頁",
        previous: "上一頁",
        next: "下一頁",
        last: "最后一頁"
      }
    }
  });

  $dataTable.find('tbody').on('click', '.audit', function () {
    var data = table.row($(this).parents('tr')).data();
    var id = data.id;
    var userid = data.userid;
    var group_id = data.group_id;
    var dynamic_id = data.dynamic_id;
    var dynamic_type = data.dynamic_type;
    var type = $(this).data('type');
    audit(id, type, userid, group_id, dynamic_id, dynamic_type)
  });

  // 審核操作
  function audit(id, type, userid, group_id, dynamic_id, dynamic_type) {
    $.post("{{ route('audit.index') }}/" + id, {
      id: id,
      type: type,
      userid: userid,
      group_id: group_id,
      dynamic_id: dynamic_id,
      dynamic_type: dynamic_type,
      _token: "{{ csrf_token() }}",
      _method: "PUT"
    }, function (data) {
      if (data.result == 0) {
        table.ajax.reload();
        toastr.success("操作成功!");
      }
    });
  }

  $("#is_audit").select2({
    placeholder: "請選擇狀態",
    minimumResultsForSearch: Infinity
  });

  // 搜索
  $("#searchBtn").click(function(){
    table.draw();
  });
/script>
 
script type="text/javascript">
  $dataTable = $("#dataTable");
  var table = $dataTable.DataTable({
    "processing": true,
    "serverSide": true,
    "pageLength": 25,
    "lengthMenu": [10, 25, 50, 75, 100, 200],
    "ajax": {
      "url": "{{ route('audit.getList') }}",
      "data": function (data) {
        data.dynamic_type = "{{ Request::get('dynamic_type', 1) }}";
        data.group_id = $("#group_id").val();
        data.dynamic_id = $("#dynamic_id").val();
        data.userid = $("#userid").val();
        data.is_audit = $("#is_audit").val();
        data.t = "{{ time() }}";
      }
    },
    "columns": [
      {"data": "id"},
      {"data": "userid"},
      {"data": "group_id"},
      {"data": "dynamic_type"},
      {"data": "dynamic_id"},
      {"data": "content"},
      {"data": "images"},
      {"data": "money"},
      {"data": "is_audit"},
      {"data": "audited_at"}
    ],
    "columnDefs": [
      {
        "render": function (data, type, row) {
          if (data == 1) {
            return "活動";
          } else if (data == 2) {
            return "動態";
          }
        },
        "targets": 3
      },
      {
        "render": function (data, type, row) {
          html = "";
          $.each(data, function (k, v) {
            html += "a href='" + v.origin + "' target='_blank'>img src='" + v.origin + "' width='160' style='margin-bottom: 2px;'>";
          });
          return html;
        },
        "targets": 6
      },
      {
        "render": function (data, type, row) {
          if (data == 0) {
            return "未審核";
          } else if (data == 1) {
            return "審核通過";
          } else if (data == -1) {
            return "審核不通過";
          }
        },
        "targets": 8
      },
      {
        "render": function (data, type, row) {
          if (row.is_audit == 0) {
            return "a class='btn btn-primary audit' data-type = 1>通過/a> a class='btn btn-danger audit' data-type = 2>不通過/a>";
          }
          return "-";
        },
        "targets": 10
      }
    ],
    "createdRow": function (row, data, index) {
      $('td', row).eq(4).attr('style', 'word-break:break-all');
      $('td', row).eq(2).attr('style', 'word-break:break-all');
      $('td', row).eq(5).attr('style', 'word-break:break-all');
    },
    "language": {
      processing: "數據加載中...",
      info: "顯示第 _START_ 至 _END_ 條,共 _TOTAL_ 條記錄",
      infoEmpty: "暫無數據",
      lengthMenu: "顯示 _MENU_ 條記錄",
      paginate: {
        first: "首頁",
        previous: "上一頁",
        next: "下一頁",
        last: "最后一頁"
      }
    }
  });
 
  $dataTable.find('tbody').on('click', '.audit', function () {
    var data = table.row($(this).parents('tr')).data();
    var id = data.id;
    var userid = data.userid;
    var group_id = data.group_id;
    var dynamic_id = data.dynamic_id;
    var dynamic_type = data.dynamic_type;
    var type = $(this).data('type');
    audit(id, type, userid, group_id, dynamic_id, dynamic_type)
  });
 
  // 審核操作
  function audit(id, type, userid, group_id, dynamic_id, dynamic_type) {
    $.post("{{ route('audit.index') }}/" + id, {
      id: id,
      type: type,
      userid: userid,
      group_id: group_id,
      dynamic_id: dynamic_id,
      dynamic_type: dynamic_type,
      _token: "{{ csrf_token() }}",
      _method: "PUT"
    }, function (data) {
      if (data.result == 0) {
        table.ajax.reload();
        toastr.success("操作成功!");
      }
    });
  }
 
  $("#is_audit").select2({
    placeholder: "請選擇狀態",
    minimumResultsForSearch: Infinity
  });
 
  // 搜索
  $("#searchBtn").click(function(){
    table.draw();
  });
/script>

本文主要記錄給自己看,不做具體的說明了。

參考鏈接

dataTables 官方文檔

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP框架Laravel插件Pagination實現自定義分頁
  • 推薦幾款用 Sublime Text 開發 Laravel 所用到的插件
  • laravel yajra插件 datatable的使用詳解

標簽:巴中 山東 張家口 梅州 林芝 威海 成都 泰州

巨人網絡通訊聲明:本文標題《在Laravel中使用DataTables插件的方法》,本文關鍵詞  在,Laravel,中,使用,DataTables,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《在Laravel中使用DataTables插件的方法》相關的同類信息!
  • 本頁收集關于在Laravel中使用DataTables插件的方法的相關信息資訊供網民參考!
  • 推薦文章
    日本免费看视频| 色综合久久天天综合观看| 欧美1区| 精品国产亚洲人成在线| 亚洲 国产精品 日韩| 日本伦理黄色大片在线观看网站| 精品久久久久久中文字幕一区| 成人a大片高清在线观看| 超级乱淫黄漫画免费| 青青久热| 国产欧美精品| 成人高清护士在线播放| 四虎久久影院| 91麻豆精品国产高清在线| 青草国产在线| 国产成人精品综合在线| 成人免费观看网欧美片| 你懂的在线观看视频| 日本特黄特色aa大片免费| 黄视频网站免费| 成人高清护士在线播放| 久久成人亚洲| 日本免费区| 尤物视频网站在线| 久久99青青久久99久久| 欧美日本免费| 久久国产精品只做精品| 四虎影视精品永久免费网站| 精品视频在线看| 国产91视频网| 天天做人人爱夜夜爽2020| 97视频免费在线| 日韩欧美一二三区| 日本特黄特黄aaaaa大片| 午夜欧美成人久久久久久| 午夜欧美成人香蕉剧场| 精品国产一级毛片| 日韩一级精品视频在线观看| 日本特黄特黄aaaaa大片| a级毛片免费全部播放| 日韩中文字幕一区| 国产a网| 欧美a级片视频| 天天做人人爱夜夜爽2020毛片| 亚洲 国产精品 日韩| 999久久66久6只有精品| 欧美一区二区三区在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本在线www| 国产成人欧美一区二区三区的| 亚洲女人国产香蕉久久精品 | 午夜激情视频在线播放| 国产精品1024永久免费视频 | 九九国产| 日本特黄特色aaa大片免费| 国产一区二区精品在线观看| 国产激情一区二区三区| 99热视热频这里只有精品| 精品国产三级a| 成人在免费观看视频国产| 国产韩国精品一区二区三区| 精品美女| 韩国三级香港三级日本三级| 国产网站免费在线观看| 成人在激情在线视频| 91麻豆精品国产自产在线| 四虎影视库国产精品一区| 成人av在线播放| 国产伦久视频免费观看 视频| 国产不卡在线观看视频| 国产精品免费久久| 国产韩国精品一区二区三区| 欧美另类videosbestsex高清| 九九精品久久| 日本免费区| 国产视频在线免费观看| 欧美激情一区二区三区中文字幕| 在线观看导航| 日本免费区| 亚洲精品永久一区| 91麻豆爱豆果冻天美星空| 国产一区二区精品久| 91麻豆精品国产片在线观看| 亚洲 激情| 久久精品免视看国产明星| 欧美另类videosbestsex高清| a级黄色毛片免费播放视频| 久久成人性色生活片| 亚洲精品影院一区二区| 一本伊大人香蕉高清在线观看| 99色视频在线观看| 日本乱中文字幕系列| 欧美激情一区二区三区在线播放| 欧美激情影院| 亚洲 男人 天堂| 麻豆系列 在线视频| 精品在线视频播放| 色综合久久天天综合| 久久精品免视看国产明星| 欧美1卡一卡二卡三新区| 九九精品久久| 久草免费资源| 九九久久99综合一区二区| 亚洲天堂在线播放| 午夜久久网| 你懂的日韩| 成人在激情在线视频| 欧美激情影院| 亚洲第一色在线| 国产伦精品一区三区视频| 国产视频一区在线| 日韩字幕在线| 四虎影视久久久| 亚洲第一视频在线播放| 欧美另类videosbestsex高清| 日韩一级精品视频在线观看| 91麻豆爱豆果冻天美星空| 精品美女| 国产亚洲精品aaa大片| 四虎影视久久久免费| 精品国产一区二区三区久久久狼 | 高清一级毛片一本到免费观看| 欧美a级片视频| 精品久久久久久中文| 日日爽天天| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产成人欧美一区二区三区的| 九九热国产视频| 日韩专区亚洲综合久久| 欧美激情一区二区三区在线| 99色视频在线观看| 二级片在线观看| 韩国三级香港三级日本三级la| 久久精品店| 一级女性全黄生活片免费| 麻豆网站在线看| 99久久精品国产国产毛片 | 91麻豆精品国产自产在线| 精品久久久久久影院免费| 精品视频免费观看| 欧美激情影院| 亚洲第一视频在线播放| 美国一区二区三区| 国产不卡在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 黄视频网站在线观看| 青青青草影院| 天天色成人网| 成人在激情在线视频| 久久成人性色生活片| 99色精品| 夜夜操网| 尤物视频网站在线观看| 国产精品123| 国产a视频| 韩国三级视频在线观看| 国产不卡在线观看视频| 韩国三级香港三级日本三级la| 99热精品在线| 亚洲不卡一区二区三区在线| 午夜久久网| 一级女性大黄生活片免费| 日本在线不卡视频| 欧美激情一区二区三区在线| 久久精品欧美一区二区| 欧美电影免费看大全| 国产视频网站在线观看| 国产激情视频在线观看| 色综合久久天天综合观看| 午夜在线观看视频免费 成人| 亚洲不卡一区二区三区在线| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产视频一区二区在线观看| 欧美国产日韩一区二区三区| a级精品九九九大片免费看| 精品视频在线观看一区二区三区| 成人影院久久久久久影院| 四虎久久精品国产| 精品国产一区二区三区久| 久久精品大片| 国产一级生活片| 精品视频在线看| 91麻豆国产福利精品| 日韩免费在线视频| 国产网站在线| 国产麻豆精品高清在线播放| 国产不卡在线观看视频| 亚欧乱色一区二区三区| 精品国产三级a| 四虎久久影院| 四虎影视久久久| 精品国产一区二区三区免费| 91麻豆精品国产自产在线 | 青青久热| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 青青久久精品国产免费看| 青青久热| 亚洲 男人 天堂| 一级女性大黄生活片免费| 中文字幕Aⅴ资源网|