webapi+DataTables

webapi + datatables

前言

以前寫過一個關於DataTables的記錄,是以前作webform的時候從後臺一次性生成html代碼,有不少弊端,就很少說了。css

此次把最近研究的DataTables結合webapi的成果記錄一下。html

DataTables 中文網

DataTables 官網

基本上全部問題都能在這倆網站找到答案前端

下面開始記錄

1. 先準備一個實體

用於DataTables請求服務端以後返回的格式化數據node

/// <summary>
/// DataTables返回實體
/// </summary>
public class BaseDataTables
{
    /// <summary>
    /// Datatables發送的draw是多少那麼服務器就返回多少
    /// </summary>
    public int draw { get; set; }

    /// <summary>
    /// 即沒有過濾的記錄數(數據庫裏總共記錄數)
    /// </summary>
    public int recordsTotal { get; set; }

    /// <summary>
    /// 過濾後的記錄數(若是有接收到前臺的過濾條件,則返回的是過濾後的記錄數)
    /// </summary>
    public int recordsFiltered { get; set; }

    /// <summary>
    /// 對象數組
    /// </summary>
    public IEnumerable data { get; set; }

    /// <summary>
    /// 錯誤提示
    /// </summary>
    public string error { get; set; }
}

2. 再來幾個實體類,用戶接收 DataTables 的信息

後面加了四個擴展參數,用於接收除了DataTables固定的參數外,本身的業務參數。後面會有記錄jquery

/// <summary>
    /// 接收DataTables回傳數據model
    /// </summary>
    public class GetDataTablesMessage
    {
        /// <summary>
        /// DataTables請求和返回都是固定的值
        /// </summary>
        public int draw { get; set; }

        /// <summary>
        /// 從哪行開始
        /// </summary>
        public int start { get; set; }

        /// <summary>
        /// 長度
        /// </summary>
        public int length { get; set; }

        /// <summary>
        /// 查詢集合
        /// </summary>
        public search search { get; set; }

        /// <summary>
        /// 排序集合
        /// </summary>
        public List<order> order { get; set; }

        /// <summary>
        /// 列集合
        /// </summary>
        public List<columns> columns { get; set; }

        /// <summary>
        /// 參數1
        /// </summary>
        public int parameter1 { get; set; }
        /// <summary>
        /// 參數2
        /// </summary>
        public int parameter2 { get; set; }
        /// <summary>
        /// 參數3
        /// </summary>
        public int parameter3 { get; set; }
        /// <summary>
        /// 參數4
        /// </summary>
        public int parameter4 { get; set; }
    }

    /// <summary>
    /// 列
    /// </summary>
    public class columns
    {
        /// <summary>
        /// 列值
        /// </summary>
        public string data { get; set; }

        /// <summary>
        /// 列名
        /// </summary>
        public string name { get; set; }

        /// <summary>
        /// 是否單列查詢
        /// </summary>
        public bool searchable { get; set; }

        /// <summary>
        /// 是否排序
        /// </summary>
        public bool orderable { get; set; }

        /// <summary>
        /// 查詢實體
        /// </summary>
        public search search { get; set; }
    }

    /// <summary>
    /// 排序
    /// </summary>
    public class order
    {
        /// <summary>
        /// 
        /// </summary>
        public int column { get; set; }

        /// <summary>
        /// 
        /// </summary>
        public string dir { get; set; }
    }

    /// <summary>
    /// DataTables 列查詢值
    /// </summary>
    public class search
    {
        /// <summary>
        /// 查詢值
        /// </summary>
        public string value { get; set; }

        /// <summary>
        /// 正則
        /// </summary>
        public bool regex { get; set; }
    }

3. 用戶類(測試支持)

/// <summary>
    /// 用戶表
    /// </summary>
    [Table("SYS_User")]
    public class SYS_User : SYS_Base_Entity
    {
        /// <summary>
        /// 主鍵 用戶ID
        /// </summary>
        [Key]
        public int User_ID { get; set; }

        /// <summary>
        /// 用戶名
        /// </summary>
        [StringLength(100)]
        public string User_Name { get; set; }

        /// <summary>
        /// 手機號碼
        /// </summary>
        [StringLength(11)]
        public string Phone { get; set; }

        /// <summary>
        /// EMail
        /// </summary>
        [StringLength(100)]
        public string Email { get; set; }

        /// <summary>
        /// Sex
        /// </summary>
        public int? Sex { get; set; }

        /// <summary>
        /// 出生年月
        /// </summary>
        [Column(TypeName = "DateTime")]
        public System.DateTime? BirthDay { get; set; }
        
        /// <summary>
        /// 備註
        /// </summary>
        [StringLength(200)]
        public string Comments { get; set; }
    }

4. WEBAPI - UserController

結合 SqlSugarweb

[RoutePrefix("UserTypeGet")]
public class SYS_UserController : ApiController
{
    ZEROContext db = new ZEROContext();

    /// <summary>
    /// DataTables數據支撐開場
    /// </summary>
    /// <param name="obj"></param>
    /// <returns></returns>
    [Route("GetAllData")]
    [HttpPost]
    public BaseDataTables<SYS_User> FenYe1([FromBody]GetDataTablesMessage obj)
    {
        BaseDataTables<SYS_User> Pagedata = new BaseDataTables<SYS_User>();

        Pagedata.draw = obj.draw;

        #region 動態拼接LINQ_WHERE

        //動態WHERE
        List<IConditionalModel> conModels = new List<IConditionalModel>();

        #region all where 用到經常使用搜索條件

        var allwhere = obj.search.value;

        if (!string.IsNullOrEmpty(allwhere))
        {
            conModels.Add(new ConditionalModel()
            {
                ConditionalType = ConditionalType.Equal,
                FieldName = "User_Name",
                FieldValue = allwhere
            });
        }

        conModels.Add(new ConditionalModel()
        {
            ConditionalType = ConditionalType.NoEqual,
            FieldName = "State",
            FieldValue = "2"
        });

        #endregion

        #region col where

        foreach (var item in obj.columns)
        {
            var col_data = item.data;

            if (item.searchable)
            {
                if (!string.IsNullOrEmpty(item.search.value))
                {
                    conModels.Add(new ConditionalModel()
                    {
                        ConditionalType = ConditionalType.Equal,
                        FieldName = col_data,
                        FieldValue = item.search.value
                    });
                }
            }
        }

        #endregion

        #endregion

        int rows = 0;

        var list = db.SqlSugarDb.Queryable<SYS_User>()
            .Where(conModels)
            .ToPageList((obj.start / obj.length) + 1, obj.length, ref rows);

        Pagedata.data = list;

        Pagedata.recordsTotal = rows;

        Pagedata.recordsFiltered = rows;

        return Pagedata;
    }

    /// <summary>
    /// 獲取單個
    /// </summary>
    /// <param name="id"></param>
    /// <returns></returns>
    [HttpGet]
    public SYS_User Huo(int id)
    {
        return db.SYS_Users.Find(id);
    }

    /// <summary>
    /// 添加
    /// </summary>
    /// <param name="u"></param>
    /// <returns></returns>
    [HttpPost]
    public int Jia([FromBody]SYS_User u)
    {
        if (ModelState.IsValid)
        {
            u.Create_By = "Creater";

            u.Create_Date = Convert.ToDateTime(DateTime.Now.ToString());

            u.State = 1;

            db.SYS_Users.Add(u);

            return db.SaveChanges();
        }
        else
        {
            return 0;
        }
    }

    /// <summary>
    /// 修改
    /// </summary>
    /// <param name="u"></param>
    /// <returns></returns>
    [HttpPut]
    public int Gai([FromBody]SYS_User u)
    {
        if (ModelState.IsValid)
        {
            #region 方法二

            db.SYS_Users.Attach(u);

            u.Update_By = "updater";

            u.Update_Date = DateTime.Now;

            var startEntity = ((IObjectContextAdapter)db).ObjectContext.ObjectStateManager.GetObjectStateEntry(u);

            foreach (PropertyInfo p in u.GetType().GetProperties())
            {
                if (p.Name != "Create_By" && p.Name != "Create_Date")
                {
                    startEntity.SetModifiedProperty(p.Name);
                }
            }

            #endregion

            return db.SaveChanges();
        }
        else
        {
            return 0;
        }
    }

    /// <summary>
    /// 刪除
    /// </summary>
    /// <param name="id"></param>
    /// <returns></returns>
    [HttpDelete]
    public int Shan(int id)
    {
        return db.SqlSugarDb.Updateable<SYS_User>(new { State = 2, User_ID = id }).ExecuteCommand();
    }

    /// <summary>
    /// 批量刪除
    /// </summary>
    /// <param name="ids"></param>
    /// <returns></returns>
    [HttpDelete]
    public int Shans([FromUri]dynamic ids)
    {
        string str = Convert.ToString(ids);

        var result = 0;

        if (!string.IsNullOrEmpty(str))
        {
            int[] array = Array.ConvertAll(str.Split(','), s => int.Parse(s));

            var list = db.SqlSugarDb.Updateable<SYS_User>()
                    .UpdateColumns(it => new SYS_User() { State = 2 })
                    .Where(it => array.Contains(it.User_ID));

            result = list.ExecuteCommand();
        }

        return result;
    }

    /// <summary>
    /// 修改狀態
    /// </summary>
    /// <param name="id"></param>
    /// <param name="status"></param>
    /// <returns></returns>
    [HttpGet]
    public int ChangeStatus(int id, int status)
    {
        ZEROContext dbz = new ZEROContext();
        return dbz.SqlSugarDb.Updateable<SYS_User>(new { State = status == 0 ? 1 : 0, User_ID = id }).ExecuteCommand();
    }
}

5. ZEROContext.cs

public class ZEROContext : DbContext
{
    /// <summary>
    /// 2019/01/06 加入SqlSugar 查詢
    /// </summary>
    /// <returns></returns>
    public SqlSugarClient SqlSugarDb;//用來處理事務多表查詢和複雜的操做

    public ZEROContext() : base("name=XLZF_write")
    {
        string sqlcontenxt = ConfigurationManager.ConnectionStrings["XLZF_Read"].ConnectionString;

        SqlSugarDb = new SqlSugarClient(new ConnectionConfig()
        {
            ConnectionString = sqlcontenxt,
            DbType = DbType.SqlServer,
            IsAutoCloseConnection = true
        });
    }
}

正菜

前端結合了H+的UIajax

1. 引用

LibJS.jssql

document.write('<script src="../style/js/jquery.min.js?v=2.1.4"></script>');
document.write('<script src="../style/js/bootstrap.min.js?v=3.3.6"></script>');
document.write('<script src="../style/js/plugins/dataTables/jquery.dataTables.min.js"></script>');
document.write('<script src="../style/js/plugins/dataTables/dataTables.bootstrap4.min.js"></script>');
document.write('<script src="../style/js/content.min.js?v=1.0.0"></script>');
document.write('<script src="../style/js/plugins/dataTables/dataTables.buttons.min.js"></script>');

LibCSS.js數據庫

document.write('<link rel="shortcut icon" href="favicon.ico">');
document.write('<link href="../style/css/bootstrap.min14ed.css?v=3.3.6" rel="stylesheet">');
document.write('<link href="../style/css/font-awesome.min93e3.css?v=4.4.0" rel="stylesheet"> ');
document.write('<!-- <link href="http://apps.bdimg.com/libs/fontawesome/4.2.0/css/font-awesome.min.css" rel="stylesheet" />-->');
document.write('<!-- Data Tables -->');
document.write('<!--<link href="../style/css/plugins/dataTables/bootstrap4alpha.css" rel="stylesheet">-->');
document.write('<link href="../style/css/plugins/dataTables/dataTables.bootstrap4.min.css" rel="stylesheet">');
document.write('<link href="../style/css/plugins/dataTables/buttons.bootstrap4.min.css" rel="stylesheet">');
document.write('<!--i-checkbox-->');
document.write('<!--<link href="../style/css/plugins/iCheck/custom.css" rel="stylesheet">-->');
document.write('<link href="../style/css/animate.min.css" rel="stylesheet">');
document.write('<link href="../style/css/style.min862f.css?v=4.1.0" rel="stylesheet">');

2. html

<!DOCTYPE html>
<html>

    <!-- Mirrored from www.zi-han.net/theme/hplus/table_data_tables.html by HTTrack Website Copier/3.x [XR&CO'2014], Wed, 20 Jan 2016 14:20:01 GMT -->

    <head>

        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">

        <title>xlzf</title>
        <meta name="keywords" content="">
        <meta name="description" content="">
        <script src="../style/LibCSS.js"></script>
        <style>
            /*對工具按鈕列表整理一下*/
            
            .dt-buttons {
                width: 400px;
            }
            
            .dataTables_length {
                width: 130px;
                float: left;
            }
            /*.btn-group{
                height: 25px;
            }*/
        </style>

    </head>

    <body class="gray-bg">
        <div class="wrapper wrapper-content">
            <!--animated fadeInRight-->
            <div class="row">
                <div class="col-sm-12">
                    <div class="ibox float-e-margins">
                        <div class="ibox-title">
                            <h5>用戶 <small>列表</small></h5>
                            <div class="ibox-tools">
                                <a class="collapse-link">
                                    <i class="fa fa-chevron-up"></i>
                                </a>
                                <a class="close-link">
                                    <i class="fa fa-times"></i>
                                </a>
                            </div>
                        </div>
                        <div class="ibox-content">
                            <table id="example" width="100%" class="table table-striped table-bordered table-hover dataTables-example">
                                <thead>
                                    <tr>
                                        <th style="text-align: center;">
                                            <input type="checkbox" class="checkall" />
                                        </th>
                                        <th>行號</th>
                                        <th>用戶ID</th>
                                        <th>用戶名稱</th>
                                        <th>電話號碼</th>
                                        <th>郵箱</th>
                                        <th>性別</th>
                                        <th>狀態</th>
                                        <th>操做</th>
                                    </tr>
                                </thead>
                                <tfoot>
                                    <tr>
                                        <th></th>
                                        <th>行號</th>
                                        <th>用戶ID</th>
                                        <th>用戶名稱</th>
                                        <th>電話號碼</th>
                                        <th>郵箱</th>
                                        <th>性別</th>
                                        <th>狀態</th>
                                        <th></th>
                                    </tr>
                                </tfoot>
                            </table>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="modal inmodal" id="myModal" tabindex="-1" role="dialog" aria-hidden="true">
            <div class="modal-dialog">
                <div class="modal-content animated bounceInRight">
                    <div class="modal-header">
                        <button type="button" class="close" data-dismiss="modal">
                            <span aria-hidden="true">&times;</span><span class="sr-only">關閉</span>
                        </button>
                        <i class="fa fa-laptop modal-icon"></i>
                        <h4 class="modal-title">用戶維護</h4>
                    </div>
                    <div class="modal-body">
                        <form class="form-horizontal m-t" id="commentForm" novalidate="novalidate">
                            <div class="form-group">
                                <label class="col-sm-3 control-label">姓名:</label>
                                <div class="col-sm-8">
                                    <input id="cname" name="name" minlength="2" type="text" class="form-control">
                                </div>
                            </div>
                            <div class="form-group">
                                <label class="col-sm-3 control-label">手機:</label>
                                <div class="col-sm-8">
                                    <input id="cphone" type="text" class="form-control" name="phone">
                                </div>
                            </div>
                            <div class="form-group">
                                <label class="col-sm-3 control-label">E-mail:</label>
                                <div class="col-sm-8">
                                    <input id="cemail" type="text" class="form-control" name="email">
                                </div>
                            </div>
                            <div class="form-group">
                                <label class="col-sm-3 control-label">SEX:</label>
                                <div class="col-sm-8">
                                    <input id="csex" type="text" class="form-control" name="sex">
                                </div>
                            </div>
                            <div class="form-group">
                                <label class="col-sm-3 control-label">Birthday:</label>
                                <div class="col-sm-8">
                                    <input id="cbirthday" type="text" class="form-control" name="birthday">
                                </div>
                            </div>
                            <div class="form-group">
                                <label class="col-sm-3 control-label">說明:</label>
                                <div class="col-sm-8">
                                    <textarea id="ccomment" name="comment" class="form-control"></textarea>
                                </div>
                            </div>
                        </form>
                    </div>
                    <div class="modal-footer">
                        <button type="button" class="btn btn-white" data-dismiss="modal">關閉</button>
                        <button type="button" class="btn btn-primary" id="btn_save">保存</button>
                    </div>
                </div>
            </div>
        </div>
        <input type="hidden" id="hf_editid">
        <script src="../style/LibJS.js"></script>
    </body>
</html>

3. js

<script>
            var rootUrl = "http://localhost:51120/";
            var urlS = rootUrl + "api/SYS_User";
            $(document).ready(function() {
                //生成每列下的seachtext
                $('#example tfoot th').each(function() {
                    var title = $('#example thead th').eq($(this).index()).text();
                    if(title != "操做" && title != "行號" && title != "狀態" && $(this).index() != 0)
                        $(this).html('<input type="text" class="form-control input-sm" placeholder="Search ' + title + '" />');
                });
                //初始化   https://blog.csdn.net/u013380777/article/details/52067483    https://datatables.net/reference/option/
                var table = $("#example").DataTable({
                    "processing": true,
                    "serverSide": true,
                    "autoWidth": true,
                    "searching": true,
                    "responsive": true,
                    "lengthChange": true,
                    "ajax": {
                        "url": rootUrl + "UserTypeGet/GetAllData",
                        "type": "post",
                        "dataType": "json",
                        "dataSrc": "data"
                    },
                    "columns": [{
                        "data": "User_ID",
                        "width": "100px",
                        "bSortable": false,
                        "render": function(data, type, full, meta) {
                            var checkHtml = '<input type="checkbox" class="checkchild"  value="' + data + '" />';
                            return checkHtml;
                        },
                        "createdCell": function(td, cellData, rowData, row, col) {
                            $(td).css('text-align', 'center');
                        }
                    }, {
                        "data": null,
                        "width": "100px",
                        "bSortable": false
                    }, {
                        "data": "User_ID",
                        "bSortable": true
                    }, {
                        "data": "User_Name",
                        "bSortable": true,
                        "cellType": "th"
                    }, {
                        "data": "Phone",
                        "bSortable": true
                    }, {
                        "data": "Email",
                        "bSortable": true
                    }, {
                        "data": "Sex",
                        "width": "10%",
                        "bSortable": true,
                        //修飾性別
                        "render": function(data, type, full, meta) {
                            if(data == 1) {
                                return "<i class='fa fa-mars'></i>";
                            } else if(data == 0) {
                                return "<i class='fa fa-venus'></i>";
                            } else {
                                return "<i class='fa fa-venus-mars'></i>";
                            }
                        }
                    }, {
                        "data": null,
                        "bSortable": false
                    }, {
                        "data": null,
                        "width": "20%"
                    }],
                    "columnDefs": [{
                        "targets": 7,
                        "orderable": false,
                        "render": function(data, type, row) {
                            var id = data.User_ID;
                            var state = data.State;
                            var cHtml = "<div class='switch'>";
                            cHtml += "<div class='onoffswitch'>";
                            cHtml += "<input type= 'checkbox' " + (state == 1 ? "checked" : "") + " class='onoffswitch-checkbox' id='" + id + "' onclick='ChangUrlStatus(" + id + "," + state + ")'>";
                            cHtml += "<label class='onoffswitch-label' for='" + id + "'>";
                            cHtml += "                <span class='onoffswitch-inner'></span>";
                            cHtml += "                <span class='onoffswitch-switch'></span>";
                            cHtml += "            </label>";
                            cHtml += "</div>";
                            cHtml += "</div>";
                            return cHtml;
                        }
                    }, {
                        "targets": 8, //操做按鈕目標列 
                        "orderable": false,
                        "render": function(data, type, row) {
                            var id = data.User_ID;
                            var html = "<div class='btn-group'>";
                            html += "<button class='btn btn-primary btn-xs' onclick='btn_row_seach(" + id + ")'><i class='fa fa-search'></i> 查看</button>";
                            html += "<button class='btn btn-warning btn-xs' onclick='btn_row_edit(" + id + ")'><i class='fa fa-pencil-square-o'></i> 編輯</button>";
                            html += "<button class='btn btn-danger btn-xs' onclick='btn_row_del(" + id + ")'><i class='fa fa-trash-o'></i> 刪除</button>";
                            html += "</div>";
                            return html;
                        }
                    }],
                    "language": {
                        "lengthMenu": '<div class="input-group">' +
                            '<div class="input-group-addon">顯示</div>' +
                            '<select class="form-control input-sm">' +
                            '<option value="5">5</option>' +
                            '<option value="10">10</option>' +
                            '<option value="20">20</option>' +
                            '</select>' +
                            '</div>',
                        "search": '<span class="label label-primary">搜索:</span>', //右上角的搜索文本,能夠寫html標籤     <input type="search" class="form-control input-sm" placeholder="sss">
                        "paginate": { //分頁的樣式內容。
                            previous: "上一頁",
                            next: "下一頁",
                            first: "第一頁",
                            last: "最後"
                        },
                        "zeroRecords": "沒有內容", //table tbody內容爲空時,tbody的內容。
                        //下面三者構成了整體的左下角的內容。
                        "info": "總共_PAGES_ 頁,顯示第_START_ 到第 _END_ ,篩選以後獲得 _TOTAL_ 條,初始_MAX_ 條 ", //左下角的信息顯示,大寫的詞爲關鍵字。
                        "infoEmpty": "0條記錄", //篩選爲空時左下角的顯示。
                        "infoFiltered": "" //篩選以後的左下角篩選提示,
                    },
                    "dom": "<'row'<'col-sm-8'l><'col-sm-4'f>>" +
                        "<'row'<'col-sm-12'tr>>" +
                        "<'row'<'col-sm-5'i><'col-sm-7'p>>",
                    "order": [2, "asc"]
                });

                var buttonHtml = "<button id='btn_add' class='btn btn-primary btn-sm'><i class='fa fa-plus'></i> 新增</button> &nbsp;&nbsp;";
                buttonHtml += "<button class='btn btn-primary btn-sm' id='btnAll'><i class='fa fa-trash'></i> 批量刪除</button> &nbsp;&nbsp;";
                $("div.col-sm-8").eq(0).append(buttonHtml); //追加到length後面

                //添加序號
                //無論是排序,仍是分頁,仍是搜索最後都會重畫,這裏監聽draw事件便可
                table.on('draw.dt', function() {
                    table.column(1, {
                        search: 'applied',
                        order: 'applied'
                    }).nodes().each(function(cell, i) {
                        //i 從0開始,因此這裏先加1
                        i = i + 1;
                        //服務器模式下獲取分頁信息,使用 DT 提供的 API 直接獲取分頁信息
                        var page = table.page.info();
                        //當前第幾頁,從0開始
                        var pageno = page.page;
                        //每頁數據
                        var length = page.length;
                        //行號等於 頁數*每頁數據長度+行號
                        var columnIndex = (i + pageno * length);
                        cell.innerHTML = columnIndex;
                    });
                });

                //監聽seachtext
                $('#example tfoot th').each(function(index) {
                    $(this).find('input').on('keyup change', function() {
                        table
                            .column(index)
                            .search(this.value)
                            .draw();
                    });
                });

                //全選
                $(".checkall").click(function() {
                    var check = $(this).prop("checked");
                    $(".checkchild").prop("checked", check);
                });

                //新增
                $("#btn_add").click(function() {
                    $("#hf_editid").val("");
                    $("#cname").val("");
                    $("#cphone").val("");
                    $("#cemail").val("");
                    $("#csex").val("");
                    $("#cbirthday").val("");
                    $("#ccomment").val("");
                    $("#myModal").modal('show');
                });

                //批量處理數據
                $('#btnAll').on('click', function() {
                    var selectLoans = [];
                    $('.checkchild').each(function() {
                        if($(this).is(':checked')) {
                            selectLoans.push($(this).val());
                        }
                    });
                    if(selectLoans.length > 0) {
                        $.ajax({
                            url: urlS + "?ids=" + selectLoans,
                            type: "Delete",
                            dataType: "json",
                            success: function(data, status) {
                                window.location.reload();
                            }
                        });
                    } else {
                        alert('至少選擇一項數據!');
                    }
                });

                //保存
                $("#btn_save").click(function() {
                    var name = $("#cname").val();
                    var phone = $("#cphone").val();
                    var email = $("#cemail").val();
                    var sex = $("#csex").val();
                    var comments = $("#ccomment").val();
                    var birthday = $("#cbirthday").val();

                    if($("#hf_editid").val().length > 0) {
                        var u = {
                            User_ID: $("#hf_editid").val(),
                            User_Name: name,
                            Phone: phone,
                            Email: email,
                            Sex: sex,
                            BirthDay: birthday,
                            Comments: comments
                        };
                        $.ajax({
                            url: urlS,
                            type: "Put",
                            data: u,
                            dataType: "json",
                            success: function(data) {
                                window.location.reload();
                            }
                        });
                    } else {
                        var u = {
                            User_Name: name,
                            Phone: phone,
                            Email: email,
                            Sex: sex,
                            BirthDay: birthday,
                            Comments: comments
                        };
                        $.ajax({
                            url: urlS,
                            type: "Post",
                            data: u,
                            dataType: "json",
                            success: function(obj) {
                                window.location.reload();
                            }
                        });
                    }
                });
            });

            //行查看按鈕
            function btn_row_seach(id) {
                $.get(urlS, {
                    "id": id
                }, function(data, status) {
                    $("#cname").val(data.User_Name);
                    $("#cphone").val(data.Phone);
                    $("#cemail").val(data.Email);
                    $("#csex").val(data.Sex);
                    $("#cbirthday").val(data.BirthDay.replace("T", " "));
                    $("#ccomment").val(data.Comments);
                    $("#btn_save").hide();
                    $("#myModal").modal('show');
                });
            }
            //行編輯按鈕
            function btn_row_edit(id) {
                $("#hf_editid").val(id);

                $.get(urlS, {
                    "id": id
                }, function(data, status) {
                    $("#cname").val(data.User_Name);
                    $("#cphone").val(data.Phone);
                    $("#cemail").val(data.Email);
                    $("#csex").val(data.Sex);
                    $("#cbirthday").val(data.BirthDay.replace("T", " "));
                    $("#ccomment").val(data.Comments);
                    $("#btn_save").show();
                    $("#myModal").modal('show');
                });
            }
            //行刪除按鈕
            function btn_row_del(id) {
                $.ajax({
                    url: urlS + "?id=" + id,
                    type: "Delete",
                    dataType: "json",
                    success: function(data, status) {
                        window.location.reload();
                    }
                });
            }
            
            //修改狀態
            function ChangUrlStatus(id, status) {
                $.ajax({
                    url: urlS + "?id=" + id + "&status=" + status,
                    type: "Get",
                    dataType: "json",
                    success: function(data, status) {
                        console.log(status);
                    }
                });
            }
        </script>

結果

Datatables

本站公眾號
   歡迎關注本站公眾號,獲取更多信息