当前位置: 首页 > news >正文

【.net core】yisha框架单页面双列表联动效果示例

 gridTable1列表数据为gridTable别表数据的子数据,点击gridTable时gridTable1列表数据更新,

@{Layout = "~/Views/Shared/_Index.cshtml";}
<div class="container-div"><div class="row"><div id="searchDiv" class="col-sm-12 search-collapse"><div class="select-list"><ul><li>合同名称:<input id="name" col="name" type="text" /></li><li>签订时间:<input id="signDate" col="signDate" type="text" /></li><li>负责人:<input id="headUser" col="headUser" type="text" /></li><li>审核状态:<input id="status" col="status" type="text" /></li><li><a id="btnSearch" class="btn btn-primary btn-sm" onclick="searchGrid()"><i class="fa fa-search"></i>&nbsp;搜索</a></li></ul></div></div><div class="btn-group-sm hidden-xs" id="toolbar"><a id="btnAdd" class="btn btn-success" onclick="showSaveForm(true)"><i class="fa fa-plus"></i> 新增</a><a id="btnEdit" class="btn btn-primary disabled" onclick="showSaveForm(false)"><i class="fa fa-edit"></i> 修改</a><a id="btnDelete" class="btn btn-danger disabled" onclick="deleteForm()"><i class="fa fa-remove"></i> 删除</a></div><div class="btn-group-sm hidden-xs" id="toolbar"><a id="btnAddDetail" class="btn btn-success" onclick="showSaveDetailForm(true)"><i class="fa fa-plus"></i> 新增</a><a id="btnEditDetail" class="btn btn-primary disabled" onclick="showSaveDetailForm(false)"><i class="fa fa-edit"></i> 修改</a><a id="btnDeleteDetail" class="btn btn-danger disabled" onclick="deleteDetailForm()"><i class="fa fa-remove"></i> 删除</a></div><div class="col-sm-12 select-table table-striped" style="min-height: 47%;max-height: 47%"><table id="gridTable" data-mobile-responsive="true"></table></div><div class="col-sm-12 select-table table-striped" style="min-height: 47%;max-height: 47%"><table id="gridTable1" data-mobile-responsive="true"></table></div></div>
</div><script type="text/javascript">var curContractId = '0'$(function () {initGrid();initDetailGrid('0');});function initGrid() {var queryUrl = '@Url.Content("~/ContractManage/Salesmanagement/GetPageListJson")';$('#gridTable').ysTable({url: queryUrl,height:'350',onClickRow: function (row) {//单击事件,点击触发gridTable1表数据更新console.log('click',row.Id)refreshDetailGrid({ ContractId :row.Id});//渲染详细列表数据},columns: [{ checkbox: true, visible: true },{ field: 'Id', title: 'Id', visible: false },{ field: 'name', title: '合同名称' },{ field: 'signDate', title: '签订时间' },//{ field: 'contractNum', title: '合同编码' },//{ field: 'internalcontractNum', title: '内部合同编号' },{ field: 'internalUnit', title: '需求单位' },{ field: 'batchName', title: '批次名称' },//{ field: 'proId', title: '产品id', visible: false },//{ field: 'proName', title: '产品名称' },//{ field: 'model', title: '型号' },{ field: 'businessType', title: '业务类型' },//{ field: 'numbers', title: '数量' },//{ field: 'unit', title: '单位' },{ field: 'contractAllMonwy', title: '合同总额' },{ field: 'mateMoney', title: '匹配总额' },{ field: 'performanceMoney', title: '履约金额' },{ field: 'unPerformanceMoney', title: '未履约金额' },{ field: 'invoicingMoney', title: '开票金额' },{ field: 'unInvoicingMoney', title: '已匹配未开票金额' },{field: 'documentLink', title: '合同文件',formatter: function (value, row, index) {if (value != '') {return '<a href="' + value + '">下载</a>'}}},{ field: 'headUser', title: '负责人' },{ field: 'addDate', title: '添加时间' },{field: 'status', title: '审核状态',formatter: function (value, row, index) {if (value == "@VerifyEnum.Pass.ParseToInt()") {return '<span class="badge badge-primary">' + "@VerifyEnum.Pass.GetDescription()" + '</span>';}else if (value == "@VerifyEnum.UnPass.ParseToInt()") {return '<span class="badge badge-danger">' + "@VerifyEnum.UnPass.GetDescription()" + '</span>';}else {return '<span class="badge badge-warning">' + "@VerifyEnum.Wait.GetDescription()" + '</span>';}}},{field: 'orderStatus', title: '订单状态',formatter: function (value, row, index) {if (value == "@SalesOrderEnum.Ordered.ParseToInt()") {return '<span class="badge badge-primary">' + "@SalesOrderEnum.Ordered.GetDescription()" + '</span>';}else if (value == "@SalesOrderEnum.Produced.ParseToInt()") {return '<span class="badge badge-primary">' + "@SalesOrderEnum.Produced.GetDescription()" + '</span>';}else if (value == "@SalesOrderEnum.Shipped.ParseToInt()") {return '<span class="badge badge-primary">' + "@SalesOrderEnum.Shipped.GetDescription()" + '</span>';}else if (value == "@SalesOrderEnum.Received.ParseToInt()") {return '<span class="badge badge-primary">' + "@SalesOrderEnum.Received.GetDescription()" + '</span>';}else if (value == "@SalesOrderEnum.Invoiced.ParseToInt()") {return '<span class="badge badge-primary">' + "@SalesOrderEnum.Invoiced.GetDescription()" + '</span>';}else {return '<span class="badge badge-warning">' + "@SalesOrderEnum.Wait.GetDescription()" + '</span>';}}},{title: '操作',align: 'center',formatter: function (value, row, index) {var actions = [];if (row.status == 0) {actions.push('<a class="btn btn-warning btn-xs" href="#" onclick="SubVaild(\'' + row.Id + '\')">审核 </a> ');}actions.push('<a class="btn btn-warning btn-xs" href="#" onclick="address(\'' + row.Id + '\')" style="margin-left:2px">合同归档文件</a>');actions.push('<a class="btn btn-warning btn-xs" href="#" onclick="detail(\'' + row.Id + '\')" style="margin-left:2px">详情 </a>');return actions.join('');}}],queryParams: function (params) {var pagination = $('#gridTable').ysTable('getPagination', params);var queryString = $('#searchDiv').getWebControls(pagination);return queryString;}});}function initDetailGrid() {var queryUrl = '@Url.Content("~/ContractManage/SealsManagementDetail/GetPageListJson")';console.log("initDetailGrid");$('#gridTable1').ysTable({url: queryUrl,height: '350',columns: [{ checkbox: true, visible: true },{ field: 'Id', title: 'Id', visible: false },{ field: 'Name', title: '名称' },{ field: 'BatchName', title: '批次名称' },{ field: 'Model', title: '型号' },{ field: 'Specs', title: '规格' },{ field: 'Unit', title: '单位' },{ field: 'Number', title: '数量' },],queryParams: function (params) {var pagination = $('#gridTable1').ysTable('getPagination', params);var queryString = $('#searchDiv1').getWebControls(pagination);queryString.ContractId = curContractId;//检索明细参数console.log('queryString', queryString);return queryString;}});}function searchGrid() {$('#gridTable').ysTable('search');resetToolbarStatus();refreshDetailGrid({ ContractId: '0' });//初始化gridTable时清空gridTable1列表数据}function refreshDetailGrid(params){//点击主表行触发事件,刷新明细表数据为当前点击主表行明细数据curContractId = params.ContractId//赋值检索明细参数$('#gridTable1').ysTable('search');//更具条件查询gridTable1表}function showSaveForm(bAdd) {var id = 0;if (!bAdd) {var selectedRow = $('#gridTable').bootstrapTable('getSelections');if (!ys.checkRowEdit(selectedRow)) {return;}else {id = selectedRow[0].Id;}}ys.openDialog({title: id > 0 ? '编辑' : '添加',content: '@Url.Content("~/ContractManage/Salesmanagement/SalesmanagementForm")' + '?id=' + id,width: '968px',height: '750px',callback: function (index, layero) {var iframeWin = window[layero.find('iframe')[0]['name']];iframeWin.saveForm(index);}});}function deleteForm() {var selectedRow = $('#gridTable').bootstrapTable('getSelections');if (ys.checkRowDelete(selectedRow)) {ys.confirm('确认要删除选中的' + selectedRow.length + '条数据吗?', function () {var ids = ys.getIds(selectedRow);ys.ajax({url: '@Url.Content("~/ContractManage/Salesmanagement/DeleteFormJson")' + '?ids=' + ids,type: 'post',success: function (obj) {if (obj.Tag == 1) {ys.msgSuccess(obj.Message);searchGrid();}else {ys.msgError(obj.Message);}}});});}}function showSaveDetailForm(bAdd) {if (curContractId == '0') {ys.msgError('请先选择合同!');return false;}var id = 0;if (!bAdd) {var selectedRow = $('#gridTable1').bootstrapTable('getSelections');if (!ys.checkRowEdit(selectedRow)) {return;}else {id = selectedRow[0].Id;}}ys.openDialog({title: id > 0 ? '编辑' : '添加',content: '@Url.Content("~/ContractManage/SealsManagementDetail/SealsManagementDetailForm")' + '?id=' + id + '&ContractId=' + curContractId,width: '50%',height: '30%',callback: function (index, layero) {var iframeWin = window[layero.find('iframe')[0]['name']];iframeWin.saveForm(index);}});}function deleteDetailForm() {var selectedRow = $('#gridTable1').bootstrapTable('getSelections');if (ys.checkRowDelete(selectedRow)) {ys.confirm('确认要删除选中的' + selectedRow.length + '条数据吗?', function () {var ids = ys.getIds(selectedRow);ys.ajax({url: '@Url.Content("~/ContractManage/SealsManagementDetail/DeleteFormJson")' + '?ids=' + ids,type: 'post',success: function (obj) {if (obj.Tag == 1) {ys.msgSuccess(obj.Message);searchGrid();}else {ys.msgError(obj.Message);}}});});}}//详情function detail(id) {ys.openDialog({title: '查看详情',content: '@Url.Content("~/ContractManage/Salesmanagement/SalesmanagementForm")' + '?id=' + id +'&sType=1',width: '968px',height: '750px',callback: function (index, layero) {var iframeWin = window[layero.find('iframe')[0]['name']];iframeWin.saveForm(index);}});}//审核function SubVaild(id) {ys.openDialog({title: '审核',content: '@Url.Content("~/ContractManage/Salesmanagement/SalesmanagementVaild")' + '?id=' + id,width: '668px',height: '450px',callback: function (index, layero) {var iframeWin = window[layero.find('iframe')[0]['name']];iframeWin.saveForm(index);}});}//合同归档文件function address(id) {ys.openDialog({title: '上传合同归档文件',content: '@Url.Content("~/ContractManage/Salesmanagement/SalesmanagementContract")' + '?id=' + id,width: '768px',height: '450px',callback: function (index, layero) {var iframeWin = window[layero.find('iframe')[0]['name']];iframeWin.saveForm(index);}});}
</script>

相关文章:

【.net core】yisha框架单页面双列表联动效果示例

gridTable1列表数据为gridTable别表数据的子数据&#xff0c;点击gridTable时gridTable1列表数据更新&#xff0c; {Layout "~/Views/Shared/_Index.cshtml";} <div class"container-div"><div class"row"><div id"search…...

01. 板载硬件资源和开发环境

一、板载硬件资源 STM32F4VGT6-DISCOVERY硬件资源如下&#xff1a; (1). STM32F407VGT6微控制器有1M的FLASH存储器&#xff0c;192K的RAM&#xff0c;LQFP100封装 (2). 板上的ST-LINK_V2可以使用选择的方式把套件切换成一个独立的ST-LINK/V2来 使用&#xff08;可以使用SWD…...

BlobDetector的使用与参数说明(OpenCV/C++)

通过opencv的BlobDetector方法可以检测斑点、圆点、椭圆等形状 以下是使用方式及代码说明&#xff1a; 1、导入必要的OpenCV库和头文件。 #include <opencv2/opencv.hpp> #include <opencv2/blob/blobdetector.hpp>2、读取图像并将其转换为灰度图像。 cv::Mat…...

行为型模式-空对象模式

在空对象模式&#xff08;Null Object Pattern&#xff09;中&#xff0c;一个空对象取代 NULL 对象实例的检查。Null 对象不是检查空值&#xff0c;而是反应一个不做任何动作的关系。这样的 Null 对象也可以在数据不可用的时候提供默认的行为。 在空对象模式中&#xff0c;我…...

爬虫采集如何解决ip被限制的问题呢?

在进行爬虫采集的过程中&#xff0c;很多开发者会遇到IP被限制的问题&#xff0c;这给采集工作带来了很大的不便。那么&#xff0c;如何解决这个问题呢&#xff1f;下面我们将从以下几个方面进行探讨。 一、了解网站的反爬机制 首先&#xff0c;我们需要了解目标网站的反爬机制…...

【ARM AMBA Q_Channel 详细介绍】

文章目录 1.1 Q_Channel 概述1.2 Q-Channel1.2.1 Q-Channel 接口1.2.2 Q-Channel 接口的握手状态1.2.3 握手信号规则 1.3 P_Channel的握手协议1.3.1 device 接受 PMU 的 power 请求1.3.2 device 拒绝 PMU 的 power 请求 1.4 device 复位信号与 Q _Channel 的结合1.4.1 RESETn 复…...

PDF Reader Pro v2.9.8(pdf编辑阅读器)

PDF Reader Pro是一款PDF阅读和编辑软件&#xff0c;具有以下特点&#xff1a; 界面设计简洁&#xff0c;易于上手。软件界面直观清晰&#xff0c;用户可以轻松浏览文档&#xff0c;编辑注释和填写表单。功能强大&#xff0c;提供了多种PDF处理工具&#xff0c;包括阅读、注释…...

【机器学习可解释性】1.模型洞察的价值

机器学习可解释性 1.模型洞察的价值2.排列的重要性3.部分图表4.SHAP Value5.SHAP Value 高级使用 正文 前言 本文是 kaggle上机器学习可解释性课程&#xff0c;共五部分&#xff0c;除第一部分介绍外&#xff0c;每部分包括辅导和练习。 此为第一部分&#xff0c;原文链接 如…...

网络安全保险行业面临的挑战与变革

保险业内大多数资产类别的数据可以追溯到几个世纪以前&#xff1b;然而&#xff0c;网络安全保险业仍处于初级阶段。由于勒索软件攻击、高度复杂的黑客和昂贵的数据泄漏事件不断增加&#xff0c;许多网络安全保险提供商开始感到害怕继续承保更多业务。 保险行业 根据最近的路…...

如何提高系统的可用性/高可用

提高系统可用性常用的一些方法&#xff0c;有缓存、异步、重试、幂等、补偿、熔断、降级、限流。 缓存 缓存的速度&#xff0c;比数据库快很多&#xff0c;添加缓存是简单有效的做法。 注意缓存与数据库的一致性&#xff0c;数据表记录变更时记得处理缓存。 Redis缓存的示例&…...

PCA和LDA数据降维计算(含数学例子推导过程)

PCA算法和LDA算法可以用于对数据进行降维&#xff0c;例如可以把一个2维的数据降低维度到一维&#xff0c;本文通过举例子来对PCA算法和LDA算法的计算过程进行教学展示。 PCA算法计算过程(文字版&#xff0c;想看具体计算下面有例子) 1.将原始数据排列成n行m列的矩阵&#xf…...

题目 1053: 二级C语言-平均值计算(python详解)——练气三层初期

✨博主&#xff1a;命运之光 &#x1f984;专栏&#xff1a;算法修炼之练气篇&#xff08;C\C版&#xff09; &#x1f353;专栏&#xff1a;算法修炼之筑基篇&#xff08;C\C版&#xff09; &#x1f352;专栏&#xff1a;算法修炼之练气篇&#xff08;Python版&#xff09; ✨…...

Python —— UI自动化之Page Object模式

1、Page Object模式简介 1、二层模型 Page Object Model&#xff08;页面对象模型&#xff09;, 或者也可称之为POM。在UI自动化测试广泛使用的一种分层设计 模式。核心是通过页面层封装所有的页面元素及操作&#xff0c;测试用例层通过调用页面层操作组装业务逻辑。 1、实战 …...

职能篇—自动驾驶产品经理

自动驾驶产品开发流程 在讲自动驾驶产品经理之前&#xff0c;先简单了解一下自动驾驶的开发体系。如上图所示&#xff0c;从产品需求开始&#xff0c;经由系统需求、系统架构、软件需求、软件架构&#xff0c;最终分解到软件代码实现模块&#xff0c;再经由MIL、SIL、HIL、VIL完…...

ubuntu安装golang

看版本&#xff1a;https://go.dev/dl/ 下载&#xff1a; wget https://go.dev/dl/go1.21.3.linux-amd64.tar.gz卸载已有的go&#xff0c;可以apt remove go&#xff0c;也可以which go之后删除那个go文件&#xff0c;然后&#xff1a; rm -rf /usr/local/go && tar…...

ES 8 新特性

1. async 和 await async 和 await 两种语法结合可以让异步代码像同步代码一样。(即:看起来是同步的,实质上是异步的。) 先从字面意思理解,async 意为异步,可以用于声明一个函数前,该函数是异步的。await 意为等待,即等待一个异步方法完成。 1.1 async async 声明(…...

linux-防火墙

目录 一、防火墙概念 1.软件防火墙 2.iptables默认规则 3.iptables的五链 4.iptables动作 5.四表五链 6.iptables实例 一、防火墙概念 linux下防火墙一般分为软件防火墙、硬件防火墙 硬件防火墙&#xff1a;在硬件的级别实现防火墙过滤功能&#xff0c;性能高&#xf…...

Pytorch--3.使用CNN和LSTM对数据进行预测

这个系列前面的文章我们学会了使用全连接层来做简单的回归任务&#xff0c;但是在现实情况里&#xff0c;我们不仅需要做回归&#xff0c;可能还需要做预测工作。同时&#xff0c;我们的数据可能在时空上有着联系&#xff0c;但是简单的全连接层并不能满足我们的需求&#xff0…...

爬虫进阶-反爬破解9(下游业务如何使用爬取到的数据+数据和文件的存储方式)

一、下游业务如何使用爬取到的数据 &#xff08;一&#xff09;常用数据存储方案 1.百万级别数据&#xff1a;单机数据库&#xff0c;搭建和使用方便快捷&#xff0c;成本低 2.千万级别数据&#xff1a;负载均衡的多台数据库&#xff0c;安全和稳定 3.海量数据&#xff1a;…...

Docker常用应用部署

Docker常用应用部署 一、Ubuntu系统Docker快速安装 Docker官网安装文档&#xff1a;https://docs.docker.com/engine/install/ubuntu/ # 文本处理的流编辑器 -i直接修改读取的文件内容&#xff0c;而不是输出到终端 # sed -i s/原字符串/新字符串/ /home/1.txt # 下面这个是修…...

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”&#xff0c;无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息&#xff1a; 关注测试号&#xff1a;扫二维码关注测试号。 发送模版消息&#xff1a; import requests da…...

【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密

在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练

前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1)&#xff1a;从基础到实战的深度解析-CSDN博客&#xff0c;但实际面试中&#xff0c;企业更关注候选人对复杂场景的应对能力&#xff08;如多设备并发扫描、低功耗与高发现率的平衡&#xff09;和前沿技术的…...

DBAPI如何优雅的获取单条数据

API如何优雅的获取单条数据 案例一 对于查询类API&#xff0c;查询的是单条数据&#xff0c;比如根据主键ID查询用户信息&#xff0c;sql如下&#xff1a; select id, name, age from user where id #{id}API默认返回的数据格式是多条的&#xff0c;如下&#xff1a; {&qu…...

Ascend NPU上适配Step-Audio模型

1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统&#xff0c;支持多语言对话&#xff08;如 中文&#xff0c;英文&#xff0c;日语&#xff09;&#xff0c;语音情感&#xff08;如 开心&#xff0c;悲伤&#xff09;&#x…...

vue3+vite项目中使用.env文件环境变量方法

vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量&#xff0c;这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...

Java面试专项一-准备篇

一、企业简历筛选规则 一般企业的简历筛选流程&#xff1a;首先由HR先筛选一部分简历后&#xff0c;在将简历给到对应的项目负责人后再进行下一步的操作。 HR如何筛选简历 例如&#xff1a;Boss直聘&#xff08;招聘方平台&#xff09; 直接按照条件进行筛选 例如&#xff1a…...

C++:多态机制详解

目录 一. 多态的概念 1.静态多态&#xff08;编译时多态&#xff09; 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1&#xff09;.协变 2&#xff09;.析构函数的重写 5.override 和 final关键字 1&#…...

Java数值运算常见陷阱与规避方法

整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...

uniapp手机号一键登录保姆级教程(包含前端和后端)

目录 前置条件创建uniapp项目并关联uniClound云空间开启一键登录模块并开通一键登录服务编写云函数并上传部署获取手机号流程(第一种) 前端直接调用云函数获取手机号&#xff08;第三种&#xff09;后台调用云函数获取手机号 错误码常见问题 前置条件 手机安装有sim卡手机开启…...