zoukankan      html  css  js  c++  java
  • EasyUI-datagrid

    初始化基本绑定:

     1 <script>
     2     $(function(){
     3          $('#tt_user_info').datagrid({
     4                 fit: true,
     5                 url: '../Data/datagrid_data.json',
     6                 method: 'get',
     7                 pagination: true,//分页
     8                 rownumbers: true,//显示行数
     9                 fitColumns: true,//自动使列适应表格宽度
    10                 singleSelect: true,//单行选择
    11                 pageSize: 50,//默认分页条数
    12                 columns: [[
    13                     { field: 'code', title: '编号',  100 },
    14                     { field: 'name', title: '名称',  100 },
    15                     { field: 'rolename', title: '角色',  100 },
    16                     { field: 'username', title: '帐号',  100 },
    17                     { field: 'password', title: '密码',  100, align: 'right' }
    18                 ]],
    19                 toolbar: '#tb_user_info'
    20             });
    21     })
    22 </script>
    23 
    24 
    25 <table id="tt_user_info"></table>
    26  <div id="tb_user_info" class="toobar-user">
    27     <a id="btn_user_add" href="#" class="easyui-linkbutton" data-options="plain:true,iconCls:'icon-add'" >添加</a>
    28     <a id="btn_user_edit" href="#" class="easyui-linkbutton" iconcls="icon-edit" plain="true">修改</a>
    29     <a id="btn_user_remove" href="#" class="easyui-linkbutton" iconcls="icon-remove" plain="true">删除</a>
    30     <input class="easyui-validatebox" type="text" /> 
    31     <a id="btn_user_search" href="#" class="easyui-linkbutton" iconcls="icon-search" plain="true">查询</a>
    32  </div>

    参考:http://www.zi-han.net/case/easyui/datagrid&tree.html#datagrid

    基本用法:

    获取取选中行某列的值:

    1 var oData = $('#tt_user_info').datagrid('getSelected');
    2 var code = oData.code;
    3 alert(code);

     刷新:

    1   $('#btn_user_reload').click(function () {
    2       $('#tt_user_info').datagrid('reload');
    3   });

    查询(两种方式):load,载入并显示第一页的记录,如果传递了'param'参数,它将会覆盖查询参数属性的值。通过传递一些参数,通常做一个查询,这个方法可以被称为从服务器加载新数据;

    reload,重载记录,跟'load'方法一样但是重载的是当前页的记录而非第一页;

    1    $('#btn_user_search').click(function () {
    2        // $('#tt_user_info').datagrid('load', { username: $('#txt_search').val(),code:"2" });
    3        $('#tt_user_info').datagrid("options").queryParams = {
    4            username: $('#txt_search').val(),
    5            code: "2"
    6        };
    7        $('#tt_user_info').datagrid('reload');
    8        $('#tt_user_info').datagrid("options").queryParams = { code: 1 };//重新绑定参数
    9    });

     绑定一列里面包含多列的方式(注意列名不能重复):

     1   var students = {
     2       total: 2,
     3       rows: [{
     4           name: "张三",
     5           age: 20,
     6           name2: "XXOO大学",
     7           address: "犄角旮旯222号"
     8                      
     9       },
    10       {
    11           name: "李四",
    12           age: 19,
    13           name2: "SB大学",
    14           address: "犄角旮旯2B号"
    15                      
    16       }
    17       ]
    18   };
    19   var jsonText = JSON.stringify(students);
    20   var oJson = JSON.parse(jsonText);
    21   $('#student').datagrid({
    22      columns: [[
    23          { field: 'name', title: '名称',rowspan:2,  100 },
    24          { field: 'age', title: '年龄', rowspan:2, 100 },
    25          { title: '学校', colspan: 2 }
    26          ],
    27          [
    28           { field: 'name2', title: '学校名称',  100 },
    29           { field: 'address', title: '学校地址',  100 }
    30          ]
    31          ]
    32  });
    33 
    34  $('#student').datagrid('loadData', oJson);

    如果只是希望把包含列的信息显示在该列下的话,也可以这么做;

     1   var students = {
     2       total: 2,
     3       rows: [{
     4           name: "张三",
     5           age: 20,
     6           school: {
     7               name: "XXOO大学",
     8               address: "犄角旮旯222号"
     9           }
    10       },
    11       {
    12           name: "李四",
    13           age: 19,
    14           school: {
    15               name: "SB大学",
    16               address: "犄角旮旯2B号"
    17           }
    18       }
    19    ]
    20   };
    21   var jsonText = JSON.stringify(students, function (key, value) {
    22       if (key == "school") {
    23           return value.name + value.address;
    24       } else {
    25           return value;
    26       }
    27   });
    28   alert(jsonText);
    29   var oJson = JSON.parse(jsonText);
    30   alert(oJson);
    31   $('#student').datagrid({
    32       columns: [[
    33                      { field: 'name', title: '名称',  100 },
    34                      { field: 'age', title: '年龄',  100 },
    35                      { field: 'school', title: '学校',  300 }
    36                  ]]
    37   });
    38   $('#student').datagrid('loadData', oJson);

    注意是把字面量对象通过JSON.stringify的第二个过滤参数修改了school的值,如果直接绑定的json的话会是下图的结果

  • 相关阅读:
    Monkey Studio IDE | The way IDEs should be
    ImportError: No module named pysqlite2 chinacloud 博客园
    EF架构——code first开发中,在修改实体时,自动影响到数据表上
    你必须要知道的架构知识~目录
    MVC中业务层是否应该有个基类?它有什么作用?
    解决COOKIES存储中文乱码的问题
    C#代码是更具艺术性的,选择她,因为喜欢她
    arm驱动程序——按键程序6_互斥1—原子操作(韦东山的视频总结及针对linux2.6.30)
    Oracle体系结构及备份(十)——sgaothers_pool
    Linux进程间通信(三)管道通信之有名管道及其基础实验
  • 原文地址:https://www.cnblogs.com/Mryjp/p/datagrid.html
Copyright © 2011-2022 走看看