【前言】
最近在开发库房系统,经常遇到easyui datagrid数据加载,但是发现加载数据有两种不同的方式,一种是ajax加载目标url返回的json数据;另一种是在加js对象,通过loadData方法(或者可以在js里创建datagrid,这样就不用loadData方法了)。

通过ajax 加载数据
在view 里设置好表格样式:

<table class="easyui-datagrid" title="我的申请" style="width: 750px; height: 250px"data-options=" singleSelect:true,@*设置为 true,则只允许选中一行。*@ collapsible:true,rownumbers:true,@*设置为 true,则显示带有行号的列。*@ autoRowHeight:false,pagination:true,@*设置为 true,则在数据网格(datagrid)底部显示分页工具栏。*@ pageSize:20">
        <thead>

            <tr>

                <th data-options="field:'ItemNo',halign:'center'">物品编号</th>
                <th data-options="field:'ItemName',halign:'center'">商品名称</th>
                <th data-options="field:'CategoryID',halign:'center'">商品类别</th>
                <th data-options="field:'Number',halign:'center'">借用数量</th>
                <th data-options="field:'Purpose',halign:'center'">用途</th>
                <th data-options="field:'Operator1',halign:'center'">审批人</th>
                <th data-options="field:'LendingDate',width:80,halign:'center'">借用时间</th>
                <th data-options="field:'ReturnDate',halign:'center'">归还时间</th>
                <th data-options="field:'OperationItem',halign:'center'">操作列</th>
              @*  <th data-options="field:'Status',halign:'center'">状态</th>*@

            </tr>
        </thead>
    </table>

用ajax 进行数据传输,从服务器获取数据,把获得的数据放到以表格列id的数组里,然后再把数据加载到表格中进行数据填充。

//ready方法为文档加载时就发生
$(document).ready(function () {
    //绑定搜索事件
    $('#btn_Search').bind('click',search_click);

    $.ajax({

        //类型为get,是要从数据库获取数据,

        type: "GET",//获取数据的地址,此地址为对应的controller,去执行对应的controller,MVC里的controller相当于三层中的U层
        url: "/MyApplication/ShowAllApplication",//连同请求发送到服务器的数据,请求参数
        data: "&applicant=" + 001,//返回的数据类型为json类型
        dataType: "json",//当controller 请求服务器成功时执行,参数data为返回的数据
        success: function (data) {
            //定义数组变量,存放着datagrid各列的ID
            var data1 = [{ "itemNo": '',"itemName": '',"categoryName": '',"number": '',"purpose": '',"userName": '',"lendingDate": '',"returnDate": '',"status": '' }]

            //循环向data1里添加数据
            for (var i = 0; i < data.length; i++) {
                data1.push({ "itemNo": data[i].itemNo,"itemName": data[i].ItemName,"categoryName": data[i].categoryName,"number": data[i].number,"purpose": data[i].purpose,"userName": data[i].userName,"lendingDate": data[i].lendingDate,"returnDate": data[i].returnDate,"status": data[i].status })
            }

            //在表格中加载数据,dg是datagrid 的ID
            $('#dg').datagrid("loadData",data1);
        }
    })
})

直接在js里加载数据
通过js里动态加载datagrid控件,数据会自动按照datagrid列colums对象的filed进行填充数据表格。创建easyui datagrid也可以写在view的html里面,这样就需要使用loaddata方法调用js对象加载数据了。

$(document).ready(function () {
   //类型为get,是要从数据库获取数据,

        type: "GET",$('#dg').datagrid({
   //通过datagrid属性设置表格样式
            width: "100%",//宽度
            striped: true,//把行条纹化(奇偶行背景色不同)
            idField: 'quesID',//标识字段
            loadMsg: '正在加载用户的信息.......',//从远程站点加载数 据时,显示的提示消息
            pagination: true,//数据网格底部显示分页工具栏
            singleSelect: false,//只允许选中一行
            Pagelist: [10,20,30,40,50],//设置每页记录条数的列表
            pageSize: 10,//初始化页面尺寸(默认分页大小)
            pageNumber: 1,//初始化页面(默认显示第一页)
            beforePageText: '第',//页数文本框前显示的汉字 
            afterPageText: '页 共 {pages} 页',displayMsg: '第{from}到{to}条,共{total}条',//数据网格列数组对象
         columns:[[
             { field: 'ItemNo',title: '商品编号',editor: 'text' },{ field: 'ItemName',title: '商品名称',{ field: 'CategoryID',title: '商品类别',{ field: 'Number',title: '借用数量',{ field: 'Purpose',title: '用途',{ field: 'Operator1',title: '审批人',{ field: 'LendingDate',title: '借用时间',{ field: 'ReturnDate',title: '归还时间',{ field: 'OperationItem',title: '操作列',formatter: btnDetailed}           
        ]]
        })
})

总结:
当我们有疑问的时候,就一定要查,放到一起比较,不讲就,同时要借鉴文档,看别人的代码(学习的过程),找联系,懂得原理,这样才能掌握到本质。PS:js 与ajax 区别是js:设置动态页面,ajax:主要是实现数据传输。

Datagrid 加载后台数据的方式的更多相关文章

  1. canvas中普通动效与粒子动效的实现代码示例

    canvas用于在网页上绘制图像、动画,可以将其理解为画布,在这个画布上构建想要的效果。本文详细的介绍了粒子特效,和普通动效进行对比,非常具有实用价值,需要的朋友可以参考下

  2. H5混合开发app如何升级的方法

    本篇文章主要介绍了H5混合开发app如何升级的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. canvas学习和滤镜实现代码

    这篇文章主要介绍了canvas学习和滤镜实现代码,利用 canvas,前端人员可以很轻松地、进行图像处理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. localStorage的过期时间设置的方法详解

    这篇文章主要介绍了localStorage的过期时间设置的方法详解的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. 详解HTML5 data-* 自定义属性

    这篇文章主要介绍了详解HTML5 data-* 自定义属性的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  6. HTML5的postMessage的使用手册

    HTML5提出了一个新的用来跨域传值的方法,即postMessage,这篇文章主要介绍了HTML5的postMessage的使用手册的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. 教你使用Canvas处理图片的方法

    本篇文章主要介绍了教你使用Canvas处理图片的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. iOS:用于填充异步提取数据的设计模式

    我正在开发一个从Web获取数据并将其显示给用户的应用程序.假设数据是餐馆的评论,并且在一个视图上显示一个评论.用户可以向左或向右滑动以转到上一个/下一个评论.数据是异步提取的.这是问题陈述–假设已经提取了5条评论,并且用户正在查看当前的第3条评论.现在,第6次审核被提取,我想将其显示为用户的第4次审核.我的模型类应该如何通知视图控制器?除上述3之外的其他建议值得欢迎!

  9. ios – 1天后firebase crashlytics报告中没有数据

    解决方法对于那些仍然有问题的人.检查您的podfile中是否还有pod’Firebase/Crash’.当我删除旧的Firebase崩溃报告时,我的问题已修复.

  10. 将AWS DynamoDB表中的数据加载到iOS上的UITableView

    我的iOS应用程序中使用Swift编写的一个屏幕是UITableView.在这个UITableView中,我想从AWSDynamoDB表中加载名为Books的数据.目前,这是我在故事板上的原型单元格:在表格中我有3个属性:“名称”,“价格”和“ISBN”.我想要的是扫描“书籍”表,并过滤结果,因此结果的“ISBN”属性将包含数字“9”.在我筛选结果后,我想将它们应用到UITableView,因此“

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部