【angularjs】angularjs+bootstrap表格组件的使用

一、table控件基本使用方法:

  • 安装bootstrap-table插件:

>bower install bootstrap-table --save
bower bootstrap-table#*         cached https://github.com/wenzhixin/bootstrap-table.git#1.11.1
bower bootstrap-table#*       validate 1.11.1 against https://github.com/wenzhixin/bootstrap-table.git#*
  • 添加相关依赖:

...
    <!-- bootstrap-table -->
    <link rel="stylesheet" href="bower_components/bootstrap-table/dist/bootstrap-table.css">
...
    <!-- bootstrap-table -->
    <script src="bower_components/bootstrap-table/dist/bootstrap-table.js"></script>
    <script src="bower_components/bootstrap-table/dist/local/bootstrap-table-zh-CN.js"></script>
  • 页面编辑:

    基于bootstrap-table插件的表格页面代码非常简单,大部分实现都在controller中。当然其实代码在view还是controller中都是习惯而已,因为最终都是编译到一起,这个熟悉MVC框架的你应该理解。
  <div class="col-md-10">
    <table id="oplog-table"></table>
  </div>
第一行表明该div使用了bootstrap的栅栏布局;第二行申明了一个table组件。
  • controller开发:

angular.module('webApp')
  .controller('OplogCtrl', function () {
    var table = new TableInit();
    table.Init();
  });

TableInit方法就是用来实现表格组件的初始化,下面附上相关代码和相关注释:

var TableInit = function() {
  var tableInit = new Object();
  tableInit.Init = function () {
    $('#oplog-table').bootstrapTable({
      url: 'data/oplog.json', //请求后台url(*)
      method: 'get', //请求后台方法(*)
      // toolbar: '#toolbar' // 工具按钮所在的容器
      striped: true, // 是否使用行间隔色
      cache: false, // 是否使用缓存,默认值为true(*)
      pagination: true, // 是否显示分页(*)
      sortable: true, // 是否启用排序
      sortOrder: "asc", // 排序方式
      queryParams: tableInit.queryParams, // ??传递参数(*)
      sidePagination: "server", // 分页方式:client表示客户端分页(*)
      pageNumber: 1, // 初始化加载第一页
      pageSize: 10, // 每页的记录行数(*)
      pageList: [10, 25, 50, 100], // 可供选择的每页行数(*)
      search: true, // 是否显示表格搜索
      strictSearch: true, // ??
      showColumns: true, // 是否显示所有列
      showRefresh: true, // 是否显示刷新按钮
      minimumCountColumns: 2, // 最少允许的列数
      clickToSelect: true, // 是否启用点击选中行
      height: 500, // 行高
      uniqueId: "ID", // 每一行的唯一标识
      showToggle: true, // 是否显示详细视图和列表视图切换按钮
      cardView: false, // 是否显示详细视图
      detailView: false, // 是否显示父子表
      columns: [{
        checkbox: true
      }, {
        field: 'time',
        title: '操作时间'
      }, {
        field: 'op_type',
        title: '操作类型'
      }, {
        field: 'op_params',
        title: '操作参数'
      }, {
        field: 'user',
        title: '用户信息'
      }, {
        field: 'enable_time',
        title: '生效时间'
      }, {
        field: 'result',
        title: '操作结果'
      }]
    });
  };

  tableInit.queryParams = function (params) {
    var temp = {
      limit: params.limit,
      offset: params.offset,
      departmentname: "",
      statu: ""
    };
    return temp;
  };

  return tableInit;
};

测试验证时,请求后台的url可以指向自定义的json结构,如上述代码中的data/oplog.json,指向的是data目录下的oplog.json的json数据:

{
  "total": 3,
  "rows": [{
    "time": "2017-03-08 10:41:20",
    "op_type": 0,
    "op_params": "{}",
    "user": 0,
    "enable_time": "",
    "result": 0
  }, {
    "time": "2017-03-08 10:41:20",
    "op_type": 0,
    "op_params": "{}",
    "user": 0,
    "enable_time": "",
    "result": 0
  }, {
    "time": "2017-03-08 10:41:20",
    "op_type": 0,
    "op_params": "{}",
    "user": 0,
    "enable_time": "",
    "result": 0
  }]
}
  • 呈现效果:

table_page.png

二、table控件添加搜索功能:

  • 安装时间控件:

    由于这里搜索需要支持时间段搜索和复选下拉框,所以先安装datetimepicker控件和:
bower install eonasdan-bootstrap-datetimepicker#latest --save
bower install bootstrap-multiselect#latest --save
  • 添加css、js依赖:

    <script src="bower_components/moment/moment.js"></script>
    <script src="bower_components/eonasdan-bootstrap-datetimepicker/build/js/bootstrap-datetimepicker.min.js"></script>
    <script src="bower_components/bootstrap-multiselect/dist/js/bootstrap-multiselect.js"></script>
    <link rel="stylesheet" href="bower_components/bootstrap-multiselect/dist/css/bootstrap-multiselect.css" />
  • 页面增加搜索框:

      <div class="panel panel-default">
        <div class="panel-heading" data-toggle="collapse" data-parent="#searchGroup" href="#searchTree">查询条件</div>
        <div id="searchTree" class="panel-collapse collapse in">
          <div class="panel-body">
            <form id="formSearch" class="form-hrizontal">
              <div class="form-group" style="margin-top: 0px">
                <div class="row">
                  <label class="control-label col-sm-1" for="oplogTimeSearchBegin">操作起始时间:</label>
                  <div class="col-md-3">
                    <div class="form-group">
                      <div class="input-group date" id="oplogTimeSearchBegin">
                        <input type="text" class="form-control"/>
                        <span class="input-group-addon">
                          <span class="glyphicon glyphicon-calendar"></span>
                        </span>
                      </div>
                    </div>
                  </div>
                  <label class="control-label col-sm-1" for="oplogTimeSearchEnd">操作结束时间:</label>
                  <div class="col-md-3">
                    <div class="form-group">
                      <div class="input-group date" id="oplogTimeSearchEnd">
                        <input type="text" class="form-control"/>
                        <span class="input-group-addon">
                          <span class="glyphicon glyphicon-calendar"></span>
                        </span>
                      </div>
                    </div>
                  </div>
                </div>
                <div class="row">
                  <label class="control-label col-sm-1" for="selSearchType">操作类型:</label>
                  <div class="col-sm-3" style="overflow:visible;">
                    <!--<input type="text" class="form-control" id="txt_search_type">-->
                    <select id="selSearchType" style="width: 100%;" multiple="multiple">
                      <option value="0">ADD</option>
                      <option value="1">DEL</option>
                    </select>
                  </div>
                  <label class="control-label col-sm-1" for="txtSearchUser">用户信息:</label>
                  <div class="col-sm-3">
                    <input type="text" class="form-control" id="txtSearchUser">
                  </div>
                </div>
                <div class="row">
                  <label class="control-label col-sm-1" for="txtSearchResult">操作结果:</label>
                  <div class="col-sm-3">
                    <input type="text" class="form-control" id="txtSearchResult">
                  </div>
                  <div class="col-sm-4" style="text-align: right">
                    <button type="button" id="btnQuery" class="btn btn-primary">查询</button>
                  </div>
                </div>
              </div>
            </form>
          </div>
        </div>
      </div>
    </div>
  • 添加搜索相应事件:

# controller主函数中
    var btnInit = new OplogButtonInit();
    btnInit.Init();
# 方法定义
var OplogButtonInit = function () {
  var btnInit = new Object();
  btnInit.Init = function () {
    $('#btnOplogQuery').click(function () {
      $(this).button('loading').delay(100).queue(function () {
        btnInit.refreshTable();
        $(this).button('reset');
        $(this).dequeue();
      });
    });
  };
  btnInit.refreshTable = function () {
    var table = new OplogTableInit();
    $('#oplogTable').bootstrapTable('refresh', {
      url: 'data/oplog_new.json',
      query: table.queryParams
    });
  };
  return btnInit;
};

上述代码中refreshTable是核心代码,实现表格刷新,传递的参数为table.queryParamsbtnInit.Init实现了查询按钮的点击响应。

  • 呈现效果:

table_search_page.png

三、table控件添加、删除记录:

  • 页面增加按钮:

    <div id="toolbar" class="btn-group">
      <button id="btn_add_natgw" type="button" class="btn btn-default">
        <span class="glyphicon glyphicon-plus" aria-hidden="true"></span>新增NAT网关
      </button>
      <button id="btn_remove_natgw" type="button" class="btn btn-default">
        <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>删除NAT网关</button>
      </button>
    </div>
  • table控件配置toolbar:

      toolbar: '#toolbar',
  • 设置按钮响应:

var NatgwButtonInit = function () {
  var btnInit = new Object();
  btnInit.Init = function () {
    $('#btn_remove_natgw').click(function () {
      var selectRows = $('#natgwTable').bootstrapTable('getSelections');
      console.log('selected rows are:', selectRows);
      $(this).button('loading').delay(10000).queue(function () {
        $('#natgwTable').bootstrapTable('removeAll');
        $(this).button('reset');
        $(this).dequeue();
      });
    });
  };
  return btnInit;
};

四、遗留问题:

  • 下拉框点击后不能显示下拉选项:
    如上图操作类型标签页后的下拉框所示,单击后不能显示选项,网上有说是因为在panel组件下,所以需要设置panelstyle='overflow: visible;'但是设置后还是没有用,而且发现表格选择一页多少航的下拉框也有同样的问题。
在提交代码时发现如下差异,加上这两个被莫名其妙删除的引用后,下拉框就能出现了....这个问题浪费了有接近一天时间...( ˇˍˇ )
code_diff.png

参考资料:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容