要实现的功能如下:当选择框选择数据源由原始数据切换到组合后数据时,界面左侧jqgrid表格随之改变。效果如下:

实现代码:

界面顶部select选择框:要点是用localStory将选择框的选择信息记录在缓存中,选择完成后重新加载页面,将选择框的选中项设置为记录到缓存中的值。

<section class="content-header">
<div class="row">
<H5 for="SelectBatchID" class="col-sm-1">选择批次</H5> <div class="col-md-3">
<select class="form-control" name="SelectBatchID" id="SelectBatchID" onchange="selet_curent_batch()">
</select>
</div> <H5 for="SelectData" class="col-sm-1">选择数据源</H5> <div class="col-md-3">
<select class="form-control" name="SelectData" id="SelectData" onchange="selet_data()">
<option value="original">原始数据</option>
<option value="combination">组合后数据</option>
</select>
</div>
</div> <Script>
if(localStorage.getItem("selected")=="original"){
$("#SelectData").val("original")
}
if(localStorage.getItem("selected")=="combination") {
$("#SelectData").val("combination");
}
var list = document.getElementById("SelectBatchID");
var post = function (url, form, callback) {
// XMLHttpRequest 对象
var xhr = new XMLHttpRequest();
xhr.open("post", url, true);
xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
var res = eval ("(" + xhr.responseText + ")");
callback(res);
}
};
xhr.send(form);
};
var form = new FormData();
post("/editor/getbatches", form, function (res) {
for(var v in res.batches) {
list.options.add(new Option(res.batches[v], v))
}
for (var i=0; i<list.options.length; i++) {
if (list.options[i].value == res.selected) {
list.options[i].selected = true;
}
}
});
var selet_curent_batch = function () {
var cur_batch = list.options[list.selectedIndex].value;
var form = new FormData();
form.append('cur_batch',cur_batch);
post("/batch/current", form, function (res) {
document.location.reload();
});
};
var selet_data =function () {
//选择数据源后刷新table
var data = $('#SelectData').val();
localStorage.setItem("selected",data.toString());
location.reload();
}
</Script>
</section>

生成表格的js:

<script>
//table
$(function(){
//页面加载完成之后执行
pageInit();
});
function pageInit(){
//创建jqGrid组件
var url;
if ($("#SelectData").val()=="original"){
url = "/getOriginalData"
}
if ($("#SelectData").val()=="combination") {
url = "/getCombinationData"
}
jQuery("#list2").jqGrid(
{
loadonce:true,
url : url,//组件创建完成之后请求数据的url
datatype : "json",//请求数据返回的类型。可选json,xml,txt
colNames : ['钻孔名称'],//jqGrid的列显示名字
colModel : [ //jqGrid每一列的配置信息。包括名字,索引,宽度,对齐方式.....
// {name : '_id',index : 'id', hidden:true},
{name : 'no',index : 'no',width : 180},
],
rowNum : -1,//一页显示多少条
// rowList : [ 10, 20, 50 ],//可供用户选择一页显示多少条
// pager : '#pager2',//表格页脚的占位符(一般是div)的id
sortname : 'id',//初始化的时候排序的字段
sortorder : "desc",//排序方式,可选desc,asc
mtype : "post",//向后台请求数据的ajax的类型。可选post,get
viewrecords : true,
caption : "钻孔列表",//表格的标题名字
multiselect: true,//复选框
// pagerpos: 'left',
recordtext: "",
height:225,
});
/*创建jqGrid的操作按钮容器*/
/*可以控制界面上增删改查的按钮是否显示*/
// jQuery("#list2").jqGrid('navGrid', '#pager2', {edit : false,add : false,del : false});
}
</script>

这样调整过后就可以实现我们想要的功能了!

jqgrid 实现表格随select框内容改变而刷新的更多相关文章

  1. 捕获input 文本框内容改变的事件(onchange,onblur,onPropertyChange比较)

    input 文本框内容改变,可以使用onchange或者onblur来判断,但onchange是在文本内容改变,然后失去焦点的时发生,onblur是在失去焦点时发生,不会自己去判断. 如: <i ...

  2. JS事件 文本框内容改变事件(onchange)通过改变文本框的内容来触发onchange事件,同时执行被调用的程序。

    文本框内容改变事件(onchange) 通过改变文本框的内容来触发onchange事件,同时执行被调用的程序. 如下代码,当用户将文本框内的文字改变后,弹出对话框"您改变了文本内容!&quo ...

  3. jquery文本框内容改变事件

    /** * 内容改变时并不会触发事件,但是在失去焦点的时候会触发. */ $("#inputid").change(function(){ console.log($(this). ...

  4. select框内容的编辑、修改、添加、删除操作

    // 添加 function col_add() { var selObj = $("#mySelect"); var value="value"; var t ...

  5. JS、JQury - 文本框内容改变事件

    例子: 效果: 前端代码: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="De ...

  6. JS来推断文本框内容改变事件

       oninput,onpropertychange,onchange的使用方法 onchange触发事件必须满足两个条件: a)当前对象属性改变,而且是由键盘或鼠标事件激发的(脚本触发无效) b) ...

  7. 动态生成select框内容

    获取动态数据,显示在select选项中,当前select在jsp页面中 <select > <option>这里放选中或者当前的数据</option> <%f ...

  8. JS和vue文本框输入改变p标签的内容测试

    文本框输入,p标签的内容自动变成文本框的内容,如下是三种方法的测试: 方法1:JS里的onchange,当文本框内容改变事件,该事件里写的方法是,获取p标签本身,然后获取文本框的值,赋值给变量,最后给 ...

  9. html5与js关于input[type='text']文本框value改变触发事件一些属性的区别oninput,onpropertychange,onchange和文本框的value点击全选状态onclick="select();"。做购物车页面时会要用到。

    关于input[type='text']文本框value改变触发事件一些属性的区别oninput,onpropertychange,onchange和文本框的点击全选状态onclick="s ...

随机推荐

  1. Tensorflow2的基本用法

    张量表示数据,用计算图搭建神经网络,用会话执行计算图,优化线上的权重(参数)->得到模型. 张量(tensor):多维数组(列表)                 阶:张量的维数. 数据类型: ...

  2. POJ1273 最大流模板

    之前自己写的,以后当一个模板的基础吧,不管是最大流,最小割,二分图匹配 下面是POJ1273的一个裸题.. 1 #include <iostream> 2 #include <cst ...

  3. 末日余晖 PC 版 下载

    末日余晖 PC 版 下载 <末日余晖>(英文名:Farlight 84)一款废土题材的射击游戏 Farlight 84 Official Trailer Farlight 84 官方预告片 ...

  4. URLSearchParams & Location & URL params parse

    URLSearchParams & Location & URL params parse URL params parse node.js env bug node.js & ...

  5. svg insert shape string bug

    svg insert shape string bug not support custom areaProps attributes ??? const svg = document.querySe ...

  6. nasm astrrev函数 x86

    xxx.asm %define p1 ebp+8 %define p2 ebp+12 %define p3 ebp+16 section .text global dllmain export ast ...

  7. k8s部署mysql数据持久化

    在这里我部署mysql的目的是为了后面将上一篇博客docker打包的el-admin镜像部署到k8s上,所以本文主要是部署mysql并实现持久化. 1.将我们的应用都部署到 el-admin 这个命名 ...

  8. 如何在ASP.NET Core中编写高效的控制器

    ​通过遵循最佳实践,可以编写更好的控制器.所谓的"瘦"控制器(指代码更少.职责更少的控制器)更容易阅读和维护.而且,一旦你的控制器很瘦,可能就不需要对它们进行太多测试了.相反,你可 ...

  9. Java 添加 、读取以及删除PPT幻灯片中的视频、音频文件

    在PPT中,可以操作很多种元素,如形状.图形.文字.图片.表格等,也可以插入视频或者音频文件,来丰富幻灯片的内容呈现方式.下面将介绍在Java程序中如何来添加视频.音频文件到PPT幻灯片,读取和删除幻 ...

  10. 遇见ZooKeeper:初识

    0. 什么是ZooKeeper ZooKeeper 是一个开源的分布式,它的设计目标是将那些复杂且容易出错的分布式协同服务封装起来,抽象出一个高效可靠的原语集,并以一系列简单的接口提供个用户使用. Z ...