通过收集表单数据,并且转换为json格式,实现表格的查询。

引入插件:不要忘记引入jquery。

<script src="${ctx}/assets/plugins/form2js/form2js.js"></script>
<script src="${ctx}/assets/plugins/form2js/js2form.js"></script>

建立一个form表单,id为searchForm。品红色标注的name字段名是作为属性名传入后台的,必须与后台规定的字段保持一致。

<div id="searchForm">
<div class="box-header with-border">
<div class="form-group col-lg-2 col-md-3 col-sm-4 col-xs-6">
<label for="orderNo">订单编号</label>
<input type="text" class="input-sm form-control" name="orderNo" placeholder="输入订单编号">
</div>
<div class="form-group col-lg-2 col-md-3 col-sm-4 col-xs-6">
<label for="state">订单状态</label>
<select name="state" class="input-sm form-control">
<option value="" selected="selected">全部</option>
<option value="0">未拆单</option>
<option value="1">已拆单</option>
</select>
</div>
<div class="form-group col-lg-2 col-md-3 col-sm-4 col-xs-6">
<label for=" initiator">发起人</label>
<input type="text" class="input-sm form-control" name="initiator" placeholder="输入发起人姓名">
</div>
<div class="form-group col-lg-2 col-md-4 col-sm-4 col-xs-12">
<label for="startDate">发起时间</label>
<div class="input-daterange input-group" id="date">
<input type="text" class="input-sm form-control" name="createdDtm" />
<span class="input-group-addon">至</span>
<input type="text" class="input-sm form-control" name="createdDtm" />
</div>
</div>
<div class="form-group col-lg-2 col-md-3 col-sm-4 col-xs-6">
<label for="type">类型</label>
<select name="type" class="input-sm form-control">
<option value="" selected="selected">全部</option>
<option value="1">搬运</option>
<option value="0">维修</option>
<option value="1,0">维修、搬运</option>
</select>
</div>
<div class="form-group col-lg-2 col-md-2 col-sm-2 col-xs-2">
<label for="search"></label>
<Button id="searchBtn" class="btn btn-sm btn-default">
<i class="glyphicon glyphicon-search"></i>&nbsp;查询
</Button>
</div>
</div>
</div>

js代码:

var searchformData={}; //定义一个全局变量收集表单数据。
$("#searchBtn").on("click", function() {
searchformData = form2js($("#searchForm")[0]);//将收集到的表单数据使用form2js转换为json格式。
console.log(searchformData);
$("#table").bootstrapTable("refresh", { //BootstrapTable定义的方法,refresh。
query: searchformData
});
});

refresh方法:刷新远程服务器上的数据,设置{query:{k:v}}来通过这个请求查询参数。具体详见BootstrapTable文档

通过文档可以看出,这个查询参数(query param)是json数据格式,所以这就体现了form2js的用处。

使用form2js后收集的表单数据如下,是json格式,这样就能从服务器加载查询的那条记录。

--------------------------------------------------------------------------------------------------------------------------------------分割线-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------

结合jquery写了原生js,可以达到类似的效果。

<div class="form-group">
<div>
<input type="text" class="searEle" name="nickname" value="" placeholder="姓名" />
<input type="text" class="searEle" name="phone" value="" placeholder="手机号码" />
<select name="sex" class="searEle">
<option value="" selected="selected">全部</option>
<option value="0">male</option>
<option value="1">female</option>
</select>
<input id="searchcus" type="button" value="查询" />
</div>
<div>
<table id="cusTable"></table>
</div>
</div>

var a = [];//定义全局变量数组a和c。
  var c;

$("#searchcus").on("click", function() {
a = []; //每次查询结束清空数组。
search();
});
function search() { //定义一个查询函数search
var x = $(".searEle").serializeArray(); //jquery序列化表格元素,返回json数据结构数据,此方法返回的是json对象而不是json字符串
   for(i = 0; i < x.length; i++) {
if(x[i].value != "") {
var searchformData = JSON.parse('{' + '"' + x[i].name + '"' + ':' + '"' + x[i].value + '"' + '}');//将json字符串转换为json对象
a.push(searchformData); //将json对象放入数组中。
}
}
c = $.extend({}, a[0], a[1],a[2]);//用一个或多个其他对象来扩展一个对象,返回被扩展的对象。将a[0],a[1],a[2]的内容整合到{}中,
不足之处在于,数组长度为多少(searEle的个数),这里就需要手动添加多少。
$("#cusTable").bootstrapTable("refresh", {
query: c
});
}

变量 x:

变量c:和form2js中的searchformData一样,json数据格式。

form2js的使用(续BootstrapTable)的更多相关文章

  1. .Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整(续)-使用配置文件动态注入

    上次实现了依赖注入,但是web项目必须要引用业务逻辑层和数据存储层的实现,项目解耦并不完全:另一方面,要同时注入业务逻辑层和数据访问层,注入的服务直接写在Startup中显得非常臃肿.理想的方式是,w ...

  2. [.NET] C# 知识回顾 - 委托 delegate (续)

    C# 知识回顾 - 委托 delegate (续) [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6046171.html 序 上篇<C# 知识回 ...

  3. iOS 开发者账号到期续费流程

    1.登录developer.apple.com,查看到期时间 2.到期提醒通知,点击Renew Membership续费(一般提前一个月提醒续费) 3.个人开发者账号续费需要支付 688人民币/年(9 ...

  4. JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(一)

    前言:出于某种原因,需要学习下Knockout.js,这个组件很早前听说过,但一直没尝试使用,这两天学习了下,觉得它真心不错,双向绑定的机制简直太爽了.今天打算结合bootstrapTable和Kno ...

  5. JS组件系列——BootstrapTable 行内编辑解决方案:x-editable

    前言:之前介绍bootstrapTable组件的时候有提到它的行内编辑功能,只不过为了展示功能,将此一笔带过了,罪过罪过!最近项目里面还是打算将行内编辑用起来,于是再次研究了下x-editable组件 ...

  6. JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(四):自定义T4模板快速生成页面

    前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4 ...

  7. JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(三):两个Viewmodel搞定增删改查

    前言:之前博主分享过knockoutJS和BootstrapTable的一些基础用法,都是写基础应用,根本谈不上封装,仅仅是避免了html控件的取值和赋值,远远没有将MVVM的精妙展现出来.最近项目打 ...

  8. 微信公众号开发系列教程一(调试环境部署续:vs远程调试)

    http://www.cnblogs.com/zskbll/p/4080328.html 目录 C#微信公众号开发系列教程一(调试环境部署) C#微信公众号开发系列教程一(调试环境部署续:vs远程调试 ...

  9. 我的bootstrapTable的应用

    $(function () { //$('#table').attr("data-url", "/conference/" + location.href.sp ...

随机推荐

  1. Inno Setup入门(二十一)——Inno Setup类参考(7)

    Install Setup 2013-02-02 11:31 378人阅读 评论(0) 收藏 举报 复选框 复选框(CheckBox)用于多个并不互斥的几个选项中作出一个或者多选择,例如字体可以有粗体 ...

  2. C#判断文字是否为汉字

    /// <summary> /// 检测一个字符串是不是以汉字开始 /// </summary> /// <param name="str">要 ...

  3. Windows环境下google protobuf入门

    我使用的是最新版本的protobuf(protobuf-2.6.1),编程工具使用VS2010.简单介绍下google protobuf: google protobuf 主要用于通讯,是google ...

  4. Spring 与 mybatis整合 Error parsing Mapper XML. Cause: java.lang.NullPointerException

    mapper配置文件中的namespace没有填:而且namespase的值应该填为:mapper的权限定名:否则还是会抛出异常 org.springframework.beans.factory.B ...

  5. 【转】javascript Object使用Array的方法

    原文: http://www.cnblogs.com/idche/archive/2012/03/17/2403894.html Array.prototype.push push向数组尾部添加一项并 ...

  6. ligerUI调用$.ligerDialog.open弹出窗口,关闭后无法获取焦点问题

    1:调用父窗口某一个文件框,获取焦点,   parent.window.document.getElementByIdx_x("roleName").focus(); 2:关闭父窗 ...

  7. WPF Template模版之寻找失落的控件【三】

    “井水不犯河水”常用来形容两个组织之间界限分明.互不相干,LogicTree与控件内部这颗小树之间就保持着这种关系.换句话说,如果UI元素树上有个X:Name=“TextBox1”的控件,某个控件内部 ...

  8. iOS多线程中performSelector

    下面两段代码都在主线程中运行,我们在看别人代码时会发现有时会直接调用,有时会利用performSelector调用,今天看到有人在问这个问题,我便做一下总结, [delegate imageDownl ...

  9. Setting DPDK+OVS+QEMU on CentOS

    Environment Build Step: these packages are needed for building dpdk+ovs: yum install -y make gcc gli ...

  10. P3414 SAC#1 - 组合数

    题目背景 本题由世界上最蒟蒻最辣鸡最撒比的SOL提供. 寂月城网站是完美信息教室的官网.地址:http://191.101.11.174/mgzd . 题目描述 辣鸡蒟蒻SOL是一个傻逼,他居然觉得数 ...