这个业务太复杂了

输入框的东西要用接口查出来,居然不是用户手动输入

然后我就要做一个翻页的查询列表:

<div form id="troublePartSearch" style="display: none;">
<h4>肇事零件搜索</h4>
<div>
<label style="margin-left: 10px; display: inline-block;">配件代码:</label>
<input id="partCode" type="text" style="width: 49%;">
</div>
<div>
<label style="margin-left: 10px;display: inline-block;">配件名称:</label>
<input id="partName" style="width: 49%;" type="text">
</div> <div align="center">
<button type="button" id="partInfoSearchBtn" class="mui-btn mui-btn-red "><span class="mui-icon mui-icon-search">&nbsp;</span>查询</button>
<button type="button" id="partInfoSearchResetBtn" class="mui-btn mui-btn-red "><span class="mui-icon mui-icon mui-icon-refreshempty">&nbsp;</span>重置</button>
</div> <hr>
<div align="center"><h4>配件选择</h4></div>
<div style="overflow: scroll;padding: 5px;">
<table border="1">
<tr>
<td>序号</td>
<td>选择</td>
<td>配件代码</td>
<td>配件名称</td>
<td>备注</td>
<td>类型</td>
<td>类别名称</td>
<td>索赔价</td>
</tr>
<tbody id="partSearch"></tbody>
</table>
</div> <div id="pagingControl">
<div style="display: flex;justify-content: space-between;padding: 5px;">
<button id="firstPage" class="mui-btn-danger">首页</button>
<button id="previousPage" class="mui-btn-danger">上一页</button>
<button id="nextPage" class="mui-btn-danger">下一页</button>
<button id="lastPage" class="mui-btn-danger">尾页</button>
</div> <div style="display: flex;justify-content: space-between;padding: 5px;">
共<span id="totalPage"></span>页, <span id="totalRecord"></span>条记录&nbsp;
当前第<span id="currentPage"></span>页
</div>
</div> <div align="center" style="margin: 5px;">
<button id="partInfoSelected" class="mui-btn-danger">确认</button>
<button id="fallBack" class="mui-btn-danger">返回</button>
</div>
</div>

所以这些都是手写的,提供了一些基本的功能,当然还有跳转指定页数,调整每页展示数量,就没工夫搞这些细节了:

接口做好了封装,只管丢参数,不需要考虑其他东西

function loadPartInfoList(pp) {
dms.sendAjaxRequset({
url : dms.getDmsPath()["partsOrder"] + "/partinfocommon/productProble/parts",
data : pp,
async : false,
timeout: 3000, //超时时间设置为3秒;
contentType: "application/json",
type: 'GET',
success: function(result) {
let len = result.rows.length;
let total = result.total;
let htmlCode = '';
if (len == 0) {
htmlCode += '<tr><td colspan="8">没有匹配的记录</td></tr>';
$partSearch.empty();
$partSearch.append(htmlCode);
$pagingControl.hide();
return;
}
console.log('肇事配件查询结果:' + JSON.stringify(result));
$totalRecord.text(total);
let tp = (total % pp.limit == 0) ? (total / pp.limit) : (parseInt(total / pp.limit) + 1);
$totalPage.text(tp);
$currentPage.text(pageIndex);
for (let i = 0; i < len; i++) {
htmlCode += '<tr>';
htmlCode += ' <td>' + (i + 1) + '</td>';
htmlCode += ' <td><input type="radio" name="partSelect" pClass="'+ result.rows[i].MAIN_PART_CLASS +'" pNo="' + result.rows[i].MAIN_PART_NO + '" pName="' + result.rows[i].MAIN_PART_NAME + '"></td>';
htmlCode += ' <td>' + result.rows[i].MAIN_PART_NO + '</td>'; // 配件代码
htmlCode += ' <td>' + result.rows[i].MAIN_PART_NAME + '</td>'; // 配件名称
htmlCode += ' <td>' + result.rows[i].PART_REMARK + '</td>'; // 备注
htmlCode += ' <td>' + result.rows[i].MAIN_PART_CLASS + '</td>'; // 类型
htmlCode += ' <td>' + result.rows[i].PARAMETER_CLASS_NAME + '</td>'; // 类别名称
htmlCode += ' <td>' + result.rows[i].PART_PRICE + ' </td>'; // 索赔价
htmlCode += '</tr>';
}
$partSearch.empty();
$partSearch.append(htmlCode);
$pagingControl.show();
},
error : function (p1, p2, p3) {
console.log(JSON.stringify(p1) + '\n' + JSON.stringify(p2) + '\n' + JSON.stringify(p3) + '\n');
}
});
}

设置对应的事件执行

// 重置 肇事配件查询条件
$partInfoSearchResetBtn.on('click', function () {
pageIndex = 1;
$partCode.val('');
$partName.val('');
$partSearch.empty();
$pagingControl.hide();
}); // 肇事配件查询按钮
$partInfoSearchBtn.on('click', function() {
pageIndex = 1;
loadPartInfoList({
sort : 'PART_NO',
order : 'DESC',
offset : (pageIndex - 1) * 10,
limit : 10,
brandCode : $brandCode.attr('bc'), // resultObj.BRAND_CODE $brandCode.text()
partNo : $partCode.val(),
partName : $partName.val()
});
});
// 首页刷新
$firstPage.on('click', function () {
if (pageIndex == 1) {
mui.alert('已经是首页了!!!');
return;
}
pageIndex = 1;
loadPartInfoList({
sort : 'PART_NO',
order : 'DESC',
offset : (pageIndex - 1) * 10,
limit : 10,
brandCode : $brandCode.attr('bc'), // resultObj.BRAND_CODE $brandCode.text()
partNo : $partCode.val(),
partName : $partName.val()
});
});
// 上一页
$previousPage.on('click', function () {
if (pageIndex == 1) {
mui.alert('已经是首页了');
return;
}
-- pageIndex;
loadPartInfoList({
sort : 'PART_NO',
order : 'DESC',
offset : (pageIndex - 1) * 10,
limit : 10,
brandCode : $brandCode.attr('bc'), // resultObj.BRAND_CODE $brandCode.text()
partNo : $partCode.val(),
partName : $partName.val()
});
});
// 下一页
$nextPage.on('click', function () {
if ($currentPage.text() == $totalPage.text()) {
mui.alert('已经是尾页了');
return;
}
++ pageIndex;
loadPartInfoList({
sort : 'PART_NO',
order : 'DESC',
offset : (pageIndex - 1) * 10,
limit : 10,
brandCode : $brandCode.attr('bc'), // resultObj.BRAND_CODE $brandCode.text()
partNo : $partCode.val(),
partName : $partName.val()
});
});
// 尾页
$lastPage.on('click', function () {
if (pageIndex == parseInt($totalPage.text())) {
mui.alert('已经是尾页了!');
return;
}
pageIndex = parseInt($totalPage.text());
loadPartInfoList({
sort : 'PART_NO',
order : 'DESC',
offset : (pageIndex - 1) * 10,
limit : 10,
brandCode : $brandCode.attr('bc'), // resultObj.BRAND_CODE $brandCode.text()
partNo : $partCode.val(),
partName : $partName.val()
});
});
// 肇事配件查询 和 PDI检查单号 确认
$partInfoSelected.on('click', function () {
let pNo = $('input[name="partSelect"]:checked').attr('pNo');
let pName = $('input[name="partSelect"]:checked').attr('pName');
let pClass = $('input[name="partSelect"]:checked').attr('pClass');
$troublePartCode.val(pNo);
$troublePartName.val(pName);
$troublePartClass.val(pClass);
$troublePartSearch.hide();
$surfaceZone.show();
});

pageIndex在js标签的上部设置

let pageIndex = 1; // 用于肇事配件查询的变量

【JavaScript】无框架翻页处理的更多相关文章

  1. yii2.0下,JqPaginator与load实现无刷新翻页

    JqPaginator下载地址http://jqpaginator.keenwon.com/ 控制器部分: <?php namespace backend\controllers; use co ...

  2. yii2.0下,JqPaginator与Pjax实现无刷新翻页

    控制器部分 <?php namespace backend\controllers; use common\models\Common; use Yii; use yii\base\Contro ...

  3. ajax无刷新翻页后,jquery失效问题的解决

    例如 $(".entry-title a").click(function () {   只对第一页有效, 修改为 $(document).on('click', ".e ...

  4. css3 --- 翻页动画 --- javascript --- 3d --- Action

    用css3和javascript做一个翻页动画<Action> 如有疑问请参照我的上一篇随笔:http://www.cnblogs.com/kodoyang/p/Html_Css3_Car ...

  5. css3 --- 翻页动画 --- javascript --- 3d --- 准备

    用css3和javascript做一个翻页动画<知识准备部分> 如有更多疑问请参照:http://www.imooc.com/learn/77 这是用css3的-webkit-transi ...

  6. Atitit easyui翻页组件与vue的集成解决方案attilax总结

    Atitit easyui翻页组件与vue的集成解决方案attilax总结 ===============使用1 ===========\paggingUtil_easyui_vue.js2 C:\U ...

  7. ajax翻页效果模仿yii框架

    ajax翻页效果,模仿yii框架. 复制代码代码如下: <!DOCTYPE html>  <html>  <head>  <title>ajax分页_w ...

  8. JAVASCRIPT实现翻页保存已勾选的项目

    <input type="checkbox" name="a" value="1" /><br/> <inpu ...

  9. ListView 无 DataSource 依然用 DataPager 翻页

    ListView 有 DataSource 使用 DataPager 翻页ListView 无 DataSource 使用 DataPager 翻页问题描述点击两次才能翻页返回上一页,内容为空解决方法 ...

  10. javascript移动端 电子书 翻页效果

    1.后端给一长串的纯文本 2.前端根据屏幕的高度,将文本切割为 n 页 3.使用插件 turn.js 将切割好的每页,加上翻书效果 <!DOCTYPE html> <html lan ...

随机推荐

  1. Windows文件管理优化-实用电脑软件(一)

    RX文件管理器 (稀奇古怪的小软件,我推荐,你点赞!) 日后更新涉及:电脑.维护.清理.小工具.手机.APP.IOS.从WEB.到到UI.从开发,设计:诚意寻找伙伴(文编类.技术类.思想类)共编,共进 ...

  2. jquery jquery的选择器

      什么是 jQuery 前端的一个方法库/函数库                 将很多过功能,封装好,我们可以直接使用             官网  https://jquery.com/    ...

  3. ETL工具-nifi干货系列 第八讲 处理器PutDatabaseRecord 写数据库(详细)

    1.本节通过一个小例子来讲解下处理器PutDatabaseRecord,该处理器的作用是将数据写入数据库. 如下流程通过处理器GenerateFlowFile 生成数据,然后通过处理器JoltTran ...

  4. 安装Ingress-Nginx

    目前,DHorse(https://gitee.com/i512team/dhorse)只支持Ingress-nginx的Ingress实现,下面介绍Ingress-nginx的安装过程. 下载安装文 ...

  5. 10分钟掌握Python缓存

    全文速览 python的不同缓存组件的使用场景和使用样例 cachetools的使用 项目背景 代码检查项目,需要存储每一步检查的中间结果,最终把结果汇总并写入文件中 在中间结果的存储中 可以使用co ...

  6. VUE中watch的详细使用教程

      1.watch是什么? watch:是vue中常用的侦听器(监听器),用来监听数据的变化 2.watch的使用方式如下 watch: { 这里写你在data中定义的变量名或别处方法名: { han ...

  7. .NET6 个人博客-推荐文章加载优化

    个人博客-推荐文章加载优化 前言 随着博客文章越来越多,那么推荐的文章也是越来越多,之前推荐文章是只推荐8篇,但是我感觉有点少,然后也是决定加一个加载按钮,也是类似与分页的效果,点击按钮可以继续加载8 ...

  8. 使用Github Action来辅助项目管理

    Github action 是一个Github官方提供的非常流行且速度集成 持续集成和持续交付(CI/CD)的工具.它允许你在GitHub仓库中自动化.定制和执行你的软件开发工作流.你可以发现.创建和 ...

  9. 基于NXP i.MX 6ULL——MQTT通信协议的开发案例

    前  言 本指导文档适用开发环境: Windows开发环境:Windows 7 64bit.Windows 10 64bit Linux开发环境:Ubuntu 18.04.4 64bit 拟机:VMw ...

  10. GuavaCache、EVCache、Tair、Aerospike 缓存框架比较

    Guava Cache.EVCache.Tair.Aerospike 是不同类型的缓存解决方案,它们各有特点和应用场景.下面我会逐一分析这些缓存系统的优势.应用场景,并提供一些基本的代码示例. Gua ...