WinForm中DataGridView显示更新数据--人性版
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
引用
namespace UI
{
public partial class FormStockList : Form
{
public FormStockList()
{
InitializeComponent();
this.dgvStockList.AutoGenerateColumns = false;//自动产生列设置为false;
} //加载商品ID的下拉列表的数据源和DGV的数据源.
private void FormStockList_Load(object sender, EventArgs e)
{
//把DataGridView中名为goodsId的下拉列表列取出来,设置重要属性.
DataGridViewComboBoxColumn col = this.dgvStockList.Columns["goodsId"] as DataGridViewComboBoxColumn;
col.DataSource = new BLL.GoodsBLL().GetModelList("");
col.DisplayMember = "Name";
col.ValueMember = "GoodsId";
col.DisplayStyle = DataGridViewComboBoxDisplayStyle.Nothing; LoadDataByPageIndex();//加载DataGridView的数据源.
} int cellRowIndex;//全局变量,存储单元格行号
int cellColumnIndex;//全局变量,存储单元格列号 int PreSelectRowIndex;//存储行号,以后用来判断是否换行.
bool isFirstSelectRow = true;//标识是否给变量PreSelectRowIndex赋过值.没为PreSelectRowIndex赋过值,则为true.
private void dgvStockList_CellClick(object sender, DataGridViewCellEventArgs e)
{
//DataGridView dgv = (DataGridView)sender;
cellRowIndex = this.dgvStockList.CurrentCell.RowIndex;//为cellRowIndex赋值
cellColumnIndex = this.dgvStockList.CurrentCell.ColumnIndex;//为cellColumnIndex赋值
if (isFirstSelectRow)//若isFirstSelectRow为true,说明PreSelectRowIndex是未赋过值
{
PreSelectRowIndex = e.RowIndex;//把当前行号赋值给PreSelectRowIndex
isFirstSelectRow = false;//说明已经给PreSelectRowIndex赋值
}
else//如果已经给PreSelectRowIndex赋值
{
if (e.RowIndex != PreSelectRowIndex)//当前选的单元格的行号和存储的行号不一样,说明换行了.
{
PreSelectRowIndex = e.RowIndex;//存储新行的行号.
SelectionRowChanged();//换行时要执行的方法.可能或重新绑定dgvStockList的数据源.
this.dgvStockList.Rows[cellRowIndex].Cells[cellColumnIndex].Selected = true;//针对可能重新绑定dgvStockList的数据源的情况,重新设置当前选中的单元格为重新绑定数据源前用户已选的单元格.
}
}
this.dgvStockList.BeginEdit(true);//dgvStockList_CellClick点击事件会选择一个单元格,BeginEdit让当前单元格可以编辑,能触发dgvStockList_CellBeginEdit事件.
} ////换行时判断是否值有变化,如果有,就把行数据更新到数据库.重新加载数据源.
private void SelectionRowChanged()
{
if (isEdit)//判断该行是否编辑过
{
if (temp.GoodsId != stock.GoodsId || temp.SCount != stock.SCount || temp.StockPrice != stock.StockPrice)//判断编辑过后该行的数据是否改变,如果改变了,就更新数据到数据库.
{
new BLL.StockBLL().Update(stock);//把变动后的行数据更新到数据库.
LoadDataByPageIndex();//重新加载dgvStockList的数据源.
}
}
isEdit = false;//重置isEdit的状态.
isFirst = true;//重置isFirst的状态.
} Model.Stock stock = null;//存储变动后的行数据的实体对象.
Model.Stock temp = null;//存储变动前的行数据的实体对象
bool isFirst = true;//标识是否是第一次编辑该行.
bool isEdit = false;//标识一行是否被编辑过.如果没有,以后就不用更新行数据到数据库. private void dgvStockList_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
{
isEdit = true;//标识该行被编辑.
stock = this.dgvStockList.SelectedRows[].DataBoundItem as Model.Stock;//把该行的对象用存入变量stock
if (isFirst)//如果是第一次要开始编辑该行,即该行还没有被编辑过.
{
temp = new Model.Stock();//存储该行最初的数据.
temp.GoodsId = stock.GoodsId;
temp.SCount = stock.SCount;
temp.StockPrice = stock.StockPrice;
isFirst = false;//标识该行不再是第一次被编辑了.
}
}
int pageIndex = ;//页索引
int pageCount = ;//每页显示几条数据
private void LoadDataByPageIndex()
{
this.dgvStockList.DataSource = new BLL.StockBLL().GetStockListByPage(pageIndex, pageCount);
}//加载dgvStockList的数据. //点击上一页
private void btnPre_Click(object sender, EventArgs e)
{
pageIndex--;
if (pageIndex < )
{
MessageBox.Show("已经第一页了"); pageIndex++; return;
}
LoadDataByPageIndex();
} //点击下一页
private void btnNext_Click(object sender, EventArgs e)
{
pageIndex++;
if (pageIndex > Model.Save.TPageCount)//Model.Save.TPageCount存的是总的页数.
{
MessageBox.Show("已经最后一页了"); pageIndex--; return;
}
LoadDataByPageIndex();
}
}
}
WinForm中DataGridView显示更新数据--人性版的更多相关文章
- WinForm中DataGridView导出为Excel(快速版)
public static void ExportExcel(DataGridView myDGV, string fileName) { string saveFileName = fileName ...
- winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色
winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色 先设置奇数行颜色,这个有个自带的属性AlternatingRowsDefaultCellStyle ...
- 【接上一篇】winform中dataGridView高度和宽度自适应填充完数据的高度和宽度,即dataGridView根据数据自适应大小
上一篇:winform中dataGridView高度自适应填充完数据的高度 winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度 ...
- winform中dataGridView高度自适应填充完数据的高度
// winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度是根据数据的多少而变动. 在load的时候,数据绑定后,加上如下代码: ...
- winform中dataGridView单元格根据值设置新值,彻底解决绑定后数据类型转换的困难
// winform中dataGridView单元格在数据绑定后,数据类型更改困难,只能迂回实现.有时候需要将数字变换为不同的文字描述,就会出现int32到string类型转换的异常,借助CellFo ...
- C# Winform中DataGridView的DataGridViewCheckBoxColumn使用方法
下面介绍Winform中DataGridView的DataGridViewCheckBoxColumn使用方法: DataGridViewCheckBoxColumn CheckBox是否选中 在判断 ...
- 在Winform中直接录入表格数据和在Vue&Elment中直接录入表格数据的比较
一般来说,录入数据的时候,我们都采用在一个窗体界面中,根据不同内容进行录入,但是有时候涉及主从表的数据录入,从表的数据有时候为了录入方便,也会通过表格控件直接录入.在Winform开发的时候,我们很多 ...
- WinForm中DataGridView复制选中单元格内容解决方案
WinForm中DataGridView鼠标选中单元格内容复制方案 1.CTR+C快捷键复制 前提:该控件ClipboardCopyMode属性设置值非Disable: 2.鼠标框选,自定义代码实现复 ...
- WPF:使用Json.NET在TreeView中树形显示JSON数据
原文 WPF:使用Json.NET在TreeView中树形显示JSON数据 据 读者可以参考这个开源的可以树形显示XML和JSON的工具: Mgen Object 603:XML/JSON树形显示小工 ...
随机推荐
- FusionCharts简单教程(三)-----如何自定义图表上的工具提示
最近有蛮多人总是问我这个FusionCharts制表的问题,帮助他们解决之后,在昨晚发现以前整理的笔记中有这个简单教程,而且以前也发表了几篇这个博文,所以就将其全部上传上来供别人参考.如有不正确之处望 ...
- 我所理解的OOP——UML六种关系
最近由于经常给公司的小伙伴儿们讲一些OOP的基本东西,每次草纸都被我弄的很尴尬,画来画去自己都乱了,有时候也会尝试使用UML表示类之间的关系,但UML从毕业后就再也没接触过了,经常会被小伙伴儿们指出继 ...
- Git Day01,仓库,commit,版本切换
1st,创建版本库: 2nd,添加文件: 3rd,修改文件,并提交: 4th,版本切换:git log查看版本:版本回退: 又回到原始版本了: 回到“未来”: 今天就到这里,明天继续.Git确实挺 ...
- C#学习系列-String与string的区别
参考:http://www.microsoftvirtualacademy.com/Content/ViewContent.aspx?et=9851&m=9832&ct=31042 如 ...
- iOS-数据持久化基础-沙盒机制
沙盒详解 1.IOS沙盒机制 IOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都要保存在此,例如图像,图标,声音,映像,属性列表,文 ...
- html5 浏览器端数据库
为什么使用浏览器端数据库:随着浏览器的处理能力不断增强,越来越多的网站开始考虑,将大量数据储存在客户端,这样可以减少用户等待从服务器获取数据的时间. 一.localStorage — 本地存储 可 ...
- 每天一个linux命令(31): /etc/group文件详解
Linux /etc/group文件与/etc/passwd和/etc/shadow文件都是有关于系统管理员对用户和用户组管理时相关的文件.linux /etc/group文件是有关于系统管理员对用户 ...
- 每天一个linux命令(30): chown命令
chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID:组可以是组名或者组ID:文件是以空格分开的要改变权限的文件列表,支持通配符.系统管理员经常使用chown命令,在将文件拷贝 ...
- chrome远程调试真机上的app
chrome远程调试真机上的app 看来要上真机了...
- CCNA网络工程师学习进程(5)路由器和交换机的登录安全配置和vlan划分
本节详细介绍路由器和交换机的登录安全配置以及VLAN划分的原理. (1)登录安全配置: 路由器登录有两种验证方式:有本地验证方式和远程验证方式.本地登录验证方式可以配置用户名和密码也可 ...