datagridview如何默认选中第一行?

greyrainbow2010 2011-12-17 11:12:16
VS2008 ,窗体程序
当按下检索按钮后,datagridview把数据集显示出来,默认是没有选中第一行的
我现在默认选中第一行

用 ds.currentrow.selected = true;
发现第一行颜色倒是变成了选中状态,但是行开头箭头符号没有,说明并没有选中第一行
因为用鼠标选择行的话,行开头会出现一个选中的三角形符号的

请问该怎么处理才能选中一行?
...全文
2500 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
zwei61 2014-03-28
  • 打赏
  • 举报
回复
唯一找到这篇与我需求一致的文章,但是没有正确答案 自己解决,所以拿出来共享下,也做个标记吧。亲自测试通过的。 var row =dgv_ExpressCompanyList.Rows[index];//index你想要选中的列index row .Selected = true;//这句是选中 dgv_ExpressCompanyList.CurrentCell =row.Cells[0];//这句是楼主最想要的效果 箭头符号
greyrainbow2010 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhangbin1988 的回复:]

datagridview有個屬性SelectionMode,選擇FullRowSelect
然後數據默認就是選擇第一條的
[/Quote]

你没看懂我说的问题
你说的这种默认选择,都是无焦点的行选中。事实上你这时候去判断一下currenrow是null
背景颜色选中了,但是真正的选中比如你鼠标单击第一行,这个时候行头会有个三角形的箭头指示符,这才叫选中。
吾非大神 2011-12-17
  • 打赏
  • 举报
回复

在检索按钮里+下面一句
dgView_RowHeaderMouseClick(null,null);


private void dgView_RowHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
dgView.CurrentRow.Selected = true;
}
ayzen1988 2011-12-17
  • 打赏
  • 举报
回复
datagridview有個屬性SelectionMode,選擇FullRowSelect
然後數據默認就是選擇第一條的
greyrainbow2010 2011-12-17
  • 打赏
  • 举报
回复
没人知道吗?
痛苦啊,试了很多方法都不行啊
DENQH 2011-12-17
  • 打赏
  • 举报
回复
 dataGridView1.Focus();
dataGridView1.Rows[0].Selected=true;
greyrainbow2010 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 dgw15042428 的回复:]

引用 2 楼 zhangbin1988 的回复:
datagridview有個屬性SelectionMode,選擇FullRowSelect
然後數據默認就是選擇第一條的


这样你试了么?
[/Quote]

这样还用试吗?呵呵,我一开始就用这种方式的
背景颜色是选中了,第一行数据确实也能取到
但是行头没有三角形箭头符号,这种选择跟鼠标单击的行选择根本就不是一回事。
你们说方法的时候,恐怕自己都没试过吧。鼠标单击行的跟这种自动选择的有区别,你们都看不到??


  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhangbin1988 的回复:]
datagridview有個屬性SelectionMode,選擇FullRowSelect
然後數據默認就是選擇第一條的
[/Quote]

这样你试了么?
苦苦的潜行者 2011-12-17
  • 打赏
  • 举报
回复
如果你后台绑定了数据,则你可以用以下方式
[code=VB.net]
with datagridview1
.BindingContext(.DataSource).Position = 1 '将绑定数据游标位置
.Rows(1).Selected = True '选中第二行
end with
[/code]

如果没有绑定数据,则可以

with datagridview1
.CurrentCell = .Rows(1).Cells(0) '设置当前单元格为第二行第一个格
.Rows(.CurrentCell.RowIndex).Selected = True '选中第二行
end with
'由于CurrentRow是只读属性,可以用CurrentCell来间接设置
YXH_cqStorage 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 aganqin 的回复:]
datagridview.Rows[0].Selected=true;第一行选中
[/Quote]
顶!!!
greyrainbow2010 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 aganqin 的回复:]

datagridview.Rows[0].Selected=true;第一行选中
[/Quote]

你没看懂我说的问题。你这根本是没有焦点的选中,跟行点击选中状态是根本不一样的
覃祖甘 2011-12-17
  • 打赏
  • 举报
回复
datagridview.Rows[0].Selected=true;第一行选中
greyrainbow2010 2011-12-17
  • 打赏
  • 举报
回复
能不能给datagridview第一行设置一个焦点??
我刚才尝试了一下,发现其他控件都可以设置focus
而datagridview我却没知道哪里可以设置焦点

vs2015+数据库,需要建的数据表如下: 1. “考试成绩管理系统用户登录”功能 具体要求: (1) 按照图示排列相应的控件,控件名称自定义,其中,界面中的图片可以不加; (2) 当输入正确的用户名和密码时,登录到主系统,如图所示,并且用户名或密码输入不正确时系统有所提示;当单击【取消】按钮时,用户名和密码被清空; (3) 程序中用到的数据库名为SCOREINFO,数据表名为userinfo,数据表结构如下图所示: (4) 数据表中的用户名和密码如下图。 2. 点击主窗体的“密码修改”菜单,完成“密码修改”功能,程序运行如下图所示: 具体要求: (1)此题必须使用数据库连接完成,原始密码必须为数据表里原有的数据,不使用数据库完成的为0分。 (2)需要建立数据库SCOREINFO及数据表userinfo,表的结构及数据第一部分的内容: (3)要有“原始密码输入错误”、“原始密码不能为空”及“两次输入密码不一致”的错误提示; (4)当单击【保存】按钮,新密码被更新到数据表中,不能更新的为0分; (5)单击【关闭】按钮,窗口关闭。 (6)3个Label;3个TextBox;2个Button 3. 完成“成绩查询”功能,程序运行如下图所示: 具体要求: (1) 按照图示排列相应的控件,界面下方是DataGridView控件; (2)程序用到的数据库名为SCOREINFO,数据表名为score,表结构如下: (3)完成的MainForm_Load事件处理程序:当加载窗体时,直接在窗体的dataGridView1控件中显示数据表的所有记录; (4)可以设查询条件:首先在组合框comboBox1中选择查询条件,并在textBox1中输入条件值(可以模糊查询,如按照姓名查询时,输入“王”,可以查所有姓王的同学的成绩),单击查询将结果显示在dataGridView1控件中。 (5)所需控件及属性:1个GroupBox,1个Label,Text为选择查询条件;1个ComboBox(Items:学号、姓名);1个TextBox;1个Button,Text为查询;1个DataGridView 4. 完成“课程信息修改”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)在数据库名为SCOREINFO中,创建数据表名为course,表结构如下: (3)当单击【查询】时,直接在窗体的dataGridView2控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时(DataGridView控件的Mouse_Click事件),“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【编辑】按钮时,【编辑】按钮变为【保存修改】,同时“学分”和“课程编码”的文本框恢复正常(ReadOnly属性为false);在文本框中修改相应的信息后单击【保存修改】,将修改后的数据更新到数据表中。 (6)所需控件及属性:1个GroupBox,3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 5. 完成“课程信息删除”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义,其中,程序刚开始运行时,“学分”和“课程编码”的文本框是只读的; (2)数据表名为course,表结构同第4部分: (3)当单击【查询】时,直接在窗体的dataGridView控件中显示数据表的所有记录; (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当选中某一行记录并单击【删除】按钮时,则该行从数据表中删除。 (6)所需控件:3个Label;3个TextBox(textBox2属性ReadOnly为True,textBox3属性ReadOnly为True);2个Button;1个DataGridView 6. 完成“课程信息添加”功能,程序运行如下图所示: 具体要求: (1)按照图示排列相应的控件,控件名称自定义; (2)程序用到的数据库和数据表名为course,表结构如下同第四部分: (3)当单击【查询】时,直接在窗体的dataGridView1控件中显示数据表的所有记 (4)当选中DataGridView控件中的某一行记录时,“课程名字”、“学分”、“课程代码”文本框中分别显示该项对应的课程信息; (5)当单击【添加】按钮时,在文本框中添加新的内容并将新内容添加到数据表中,并且在DataGridView控件中显示出新的课程信息 (6)所需控件:3个Label;3个TextBox;2个Button;1个DataGridView

110,536

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧