zoukankan      html  css  js  c++  java
  • 代码演示用 KnockoutJS 和 Web API 对一个表格(Gird)进行 CRUD 操作,在 MVC 5 下

    实体类:

        using System;
        using System.Collections.Generic;
        
        public partial class EmployeeInfo
        {
            public int EmpNo { get; set; }
            public string EmpName { get; set; }
            public string DeptName { get; set; }
            public string Designation { get; set; }
            public decimal Salary { get; set; }
        }

    控制器:

    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.Entity;
    using System.Data.Entity.Infrastructure;
    using System.Linq;
    using System.Net;
    using System.Net.Http;
    using System.Web.Http;
    using System.Web.Http.Description;
    using MVC5_Editable_Table.Models;
    
    namespace MVC5_Editable_Table.Controllers
    {
        public class EmployeeInfoAPIController : ApiController
        {
            private ApplicationEntities db = new ApplicationEntities();
    
            // GET api/EmployeeInfoAPI
            public IQueryable<EmployeeInfo> GetEmployeeInfoes()
            {
                return db.EmployeeInfoes;
            }
    
            // GET api/EmployeeInfoAPI/5
            [ResponseType(typeof(EmployeeInfo))]
            public IHttpActionResult GetEmployeeInfo(int id)
            {
                EmployeeInfo employeeinfo = db.EmployeeInfoes.Find(id);
                if (employeeinfo == null)
                {
                    return NotFound();
                }
    
                return Ok(employeeinfo);
            }
    
            // PUT api/EmployeeInfoAPI/5
            public IHttpActionResult PutEmployeeInfo(int id, EmployeeInfo employeeinfo)
            {
                if (!ModelState.IsValid)
                {
                    return BadRequest(ModelState);
                }
    
                if (id != employeeinfo.EmpNo)
                {
                    return BadRequest();
                }
    
                db.Entry(employeeinfo).State = EntityState.Modified;
    
                try
                {
                    db.SaveChanges();
                }
                catch (DbUpdateConcurrencyException)
                {
                    if (!EmployeeInfoExists(id))
                    {
                        return NotFound();
                    }
                    else
                    {
                        throw;
                    }
                }
    
                return StatusCode(HttpStatusCode.NoContent);
            }
    
            // POST api/EmployeeInfoAPI
            [ResponseType(typeof(EmployeeInfo))]
            public IHttpActionResult PostEmployeeInfo(EmployeeInfo employeeinfo)
            {
                if (!ModelState.IsValid)
                {
                    return BadRequest(ModelState);
                }
    
                db.EmployeeInfoes.Add(employeeinfo);
                db.SaveChanges();
    
                return CreatedAtRoute("DefaultApi", new { id = employeeinfo.EmpNo }, employeeinfo);
            }
    
            // DELETE api/EmployeeInfoAPI/5
            [ResponseType(typeof(EmployeeInfo))]
            public IHttpActionResult DeleteEmployeeInfo(int id)
            {
                EmployeeInfo employeeinfo = db.EmployeeInfoes.Find(id);
                if (employeeinfo == null)
                {
                    return NotFound();
                }
    
                db.EmployeeInfoes.Remove(employeeinfo);
                db.SaveChanges();
    
                return Ok(employeeinfo);
            }
    
            protected override void Dispose(bool disposing)
            {
                if (disposing)
                {
                    db.Dispose();
                }
                base.Dispose(disposing);
            }
    
            private bool EmployeeInfoExists(int id)
            {
                return db.EmployeeInfoes.Count(e => e.EmpNo == id) > 0;
            }
        }
    }

    视图:

    @{
        ViewBag.Title = "Index";
    }
    
    <h2>CRUD Operationson HTML Table  using HTML Templates</h2>
    
    <style type="text/css">
        table {
            width: 700px;
            border: double;
        }
    
        th {
            width: 100px;
        }
    
        td {
            border: double;
            width: 100px;
        }
    
        input {
            width: 100px;
        }
    </style>
    <script src="~/Scripts/jquery-2.1.0.min.js"></script>
    <script src="~/Scripts/knockout-3.1.0.js"></script>
     
    
    <input type="button" value="Add New Record" data-bind="click: function () { EmpViewModel.addnewRecord(); }" />
    <table>
        <thead>
            <tr>
                <th>
                    EmpNo
                </th>
                <th>
                    EmpName
                </th>
                <th>
                    DeptName
                </th>
                <th>
                    Desigation
                </th>
                <th>
                    Salary
                </th>
                <th>
                </th>
                <th>
                </th>
            </tr>
        </thead>
        <tbody data-bind="template: { name: currentTemplate, foreach: Employees }"></tbody>
    </table>
    
    
    <script type="text/html" id="readonlyTemplate">
        @*  <table>*@
        <tr>
            <td>
                <span data-bind="text: EmpNo"></span>
            </td>
            <td>
                <span data-bind="text: EmpName"></span>
            </td>
            <td>
                <span data-bind="text: DeptName"></span>
            </td>
            <td>
                <span data-bind="text: Designation"></span>
            </td>
            <td>
                <span data-bind="text: Salary"></span>
            </td>
            <td>
                <input type="button" value="Edit" data-bind="click: function () { EmpViewModel.editTemplate($data);}" />
            </td>
            <td>
                <input type="button" value="delete" data-bind="click: function () { EmpViewModel.deleteEmployee($data); }" />
            </td>
        </tr>
        @* </table>*@
    </script>
    
    <script type="text/html" id="editTemplate">
        @* <table>*@
        <tr>
            <td>
                <input type="text" data-bind="value: $data.EmpNo" id="txteno" disabled="disabled" />
            </td>
            <td>
                <input type="text" data-bind="value: $data.EmpName" id="txtename" />
            </td>
            <td>
                <input type="text" data-bind="value: $data.DeptName" id="txtdname" />
            </td>
            <td>
                <input type="text" data-bind="value: $data.Designation" id="txtdesig" />
            </td>
            <td>
                <input type="text" data-bind="value: $data.Salary" id="txtsal" />
            </td>
            <td>
                <input type="button" value="Save" data-bind="click: EmpViewModel.saveEmployee" />
            </td>
            <td>
                <input type="button" value="Cancel" data-bind="click: function () { EmpViewModel.reset(); }" />
            </td>
        </tr>
        @*       </table>*@
    </script>
    
    
    <script type="text/javascript">
    
    
        var self = this;
        //S1:Boolean to check wheather the operation is for Edit and New Record
        var IsNewRecord = false;
    
        self.Employees = ko.observableArray([]);
    
        loadEmployees();
    
        //S2:Method to Load all Employees by making call to WEB API GET method
        function loadEmployees() {
            $.ajax({
                type: "GET",
                url: "api/EmployeeInfoAPI",
                success: function (data) {
                    alert("Success");
                    self.Employees(data);
                },
                error: function (err) {
                    alert(err.status + " <--------------->");
                }
            });
    
        };
        alert("Loading Data");
    
        //S3:The Employee Object
        function Employee(eno, ename, dname, desig, sal) {
            return {
                EmpNo: ko.observable(eno),
                EmpName: ko.observable(ename),
                DeptName: ko.observable(dname),
                Designation: ko.observable(desig),
                Salary: ko.observable(sal)
            }
        };
    
        //S4:The ViewModel where the Templates are initialized
        var EmpViewModel = {
            readonlyTemplate: ko.observable("readonlyTemplate"),
            editTemplate: ko.observable()
        };
    
        //S5:Method ti decide the Current Template (readonlyTemplate or editTemplate)
        EmpViewModel.currentTemplate = function (tmpl) {
            return tmpl === this.editTemplate() ? 'editTemplate' : this.readonlyTemplate();
        }.bind(EmpViewModel);
    
        //S6:Method to create a new Blabk entry When the Add New Record button is clicked
        EmpViewModel.addnewRecord = function () {
            alert("Add Called");
            self.Employees.push(new Employee(0, "", "", "", 0.0));
            IsNewRecord = true; //Set the Check for the New Record
        };
    
    
        //S7:Method to Save the Record (This is used for Edit and Add New Record)
        EmpViewModel.saveEmployee = function (d) {
    
            var Emp = {};
            Emp.EmpNo = d.EmpNo;
            Emp.EmpName = d.EmpName;
            Emp.DeptName = d.DeptName;
            Emp.Designation = d.Designation;
            Emp.Salary = d.Salary;
            //Edit teh Record
            if (IsNewRecord === false) {
                $.ajax({
                    type: "PUT",
                    url: "api/EmployeeInfoAPI/" + Emp.EmpNo,
                    data: Emp,
                    success: function (data) {
                        alert("Record Updated Successfully " + data.status);
                        EmpViewModel.reset();
                    },
                    error: function (err) {
                        alert("Error Occures, Please Reload the Page and Try Again " + err.status);
                        EmpViewModel.reset();
                    }
                });
            }
            //The New Record
            if (IsNewRecord === true) {
                IsNewRecord = false;
                $.ajax({
                    type: "POST",
                    url: "api/EmployeeInfoAPI",
                    data: Emp,
                    success: function (data) {
                        alert("Record Added Successfully " + data.status);
                        EmpViewModel.reset();
                        loadEmployees();
                    },
                    error: function (err) {
                        alert("Error Occures, Please Reload the Page and Try Again " + err.status);
                        EmpViewModel.reset();
                    }
                });
            }
        };
    
        //S8:Method to Delete the Record
        EmpViewModel.deleteEmployee = function (d) {
    
            $.ajax({
                type: "DELETE",
                url: "api/EmployeeInfoAPI/" + d.EmpNo,
                success: function (data) {
                    alert("Record Deleted Successfully " + data.status);
                    EmpViewModel.reset();
                    loadEmployees();
                },
                error: function (err) {
                    alert("Error Occures, Please Reload the Page and Try Again " + err.status);
                    EmpViewModel.reset();
                }
            });
        };
    
    
    
        //S9:Method to Reset the template
        EmpViewModel.reset = function (t) {
            this.editTemplate("readonlyTemplate");
        };
    
    
        ko.applyBindings(EmpViewModel);
    </script>

    图文介绍地址:http://www.dotnetcurry.com/showarticle.aspx?ID=1006

    代码下载:https://github.com/dotnetcurry/htmltable-mvc-webapi

    谢谢浏览!

  • 相关阅读:
    申请国家自然科学基金项目的一点体会(周浙昆)
    漫谈影响自然基金申请的因素
    凡是过往,皆为序章—写在2018年国基揭榜之时
    再谈国家基金项目申请中的几个问题
    国家基金申请书中的科学问题与关键问题
    我喜欢这样的国家自然科学基金本子
    Fedora 28 —— install fonts for WPS
    清华11篇撤稿背后:院方早已处理,被曝光才公开结果
    CPU:chip、core 和 processor 的关系
    Fedora 28 —— chm 阅读器
  • 原文地址:https://www.cnblogs.com/Music/p/crud-with-KnockoutJS-and-webapi-mvc5.html
Copyright © 2011-2022 走看看