首 页 | 新 闻 | 技术中心 | 第二书店 | 《程序员》 | 《开发高手》 | 社 区 | 黄 页 | 人 才
移 动专 题SUNIBM微 软微 创精 华Donews人 邮
我的技术中心 
我的分类 我的文档
全部文章 发表文章
专栏管理 使用说明



 RSS 订阅 
最新文档列表
Windows/.NET
.NET  (rss)    
Visual C++  (rss)    
Delphi  (rss)    
Visual Basic  (rss)    
ASP  (rss)    
JavaScript  (rss)    
Java/Linux
Java  (rss)    
Perl  (rss)    
综合
其他开发语言  (rss)    
文件格式  (rss)    
企业开发
游戏开发  (rss)    
网站制作技术  (rss)    
数据库
数据库开发  (rss)    
软件工程
其他  (rss)    

积极原创作者 
goodboy1881 (13)
wangchinaking (58)
iiprogram (67)
fancyhf (1)
harrymeng (41)
yjz0065 (113)
coofucoo (105)
Drate (69)
lphpc (30)
smallnest (61)
CSDN - 文档中心 - .NET 阅读:15378   评论: 2    参与评论
标题   DataGrid使用技巧(一)     选择自 dy_2000_abc 的 Blog
关键字   DataGrid,使用技巧
出处  

DataGrid使用技巧(一)

-------如何屏蔽单元格输入

       有时候听有些朋友抱怨.NET的DataGrid不是很好用。就我个人的体会,DataGrid的功能非常强大,可以使我们随心所欲的完成各种各样的工作,可惜就是实现起来不够简单明了。我对平时经常碰到的一些问题积累了一些解决的方法,现在把它们总结一下供大家参考。

       比较经常碰到的一个问题是:我们希望DataGrid的某一列只能输入特定的文本,比如:不能输入数字。下面的例子说明如何实现这种功能。
       新建一个Window应用程序,加入一个DataGrid和SqlConnection,连接SQL数据库NorthWind。


namespace WindowsApplication1
{
public class Form1 : System.Windows.Forms.Form
{
          private myDataGrid dataGrid1;
          private System.Data.SqlClient.SqlConnection sqlConnection1;
           //加入全局变量oldValue,用它表示单元格原来的文本。
          private string oldValue;

          private void Form1_Load(object sender, System.EventArgs e)
        {
        oldValue="";
        SqlDataAdapter sda=new SqlDataAdapter("select LastName,FirstName from employees",this.sqlConnection1);
        DataSet ds=new DataSet();
        sda.Fill(ds,"employees");
        DataGridTableStyle ats=new DataGridTableStyle();
        ats.MappingName="employees";
        DataGridColorColumn dcs1=new DataGridColorColumn();
        dcs1.HeaderText="lastname";
        ats.GridColumnStyles.Add(dcs1);
        DataGridTextBoxColumn dcs2=new DataGridTextBoxColumn();
        dcs2.HeaderText="firstname";
        dcs2.MappingName="FirstName";
        dcs2.TextBox.TextChanged+=new EventHandler(DataGridTextChanged);
        dcs2.TextBox.Enter+=new EventHandler(DataGridTextBox_Enter);
        ats.GridColumnStyles.Add(dcs2);
        this.dataGrid1.TableStyles.Add(ats);
        this.dataGrid1.DataSource=ds;
        this.dataGrid1.DataMember="employees";  
        }
       

       private void DataGridTextBox_Enter(object sender,EventArgs e)
       {
          //当某一单元格获得焦点时,记录单元格的文本
         oldValue=((DataGridTextBoxColumn) this.dataGrid1.TableStyles[0].GridColumnStyles[1]).TextBox.Text;
       }
      

       private void DataGridTextChanged(object sender,EventArgs e)
      {
           int index=0;
           string str=((DataGridTextBoxColumn)this.dataGrid1.TableStyles[0].GridColumnStyles[1]).TextBox.Text;
           //当单元格的文本改变时,检验是否有非法字符
            while(index<str.Length)
           {
           //如果发现数字,显示错误信息并将单元格还原为原内容
           if (Char.IsDigit(str,index))
           {
            MessageBox.Show("不能输入数字,请重新输入");
            ((DataGridTextBoxColumn)this.dataGrid1.TableStyles[0].GridColumnStyles[1]).TextBox.Text=oldValue;
            return;
            }
             index++;
        }
}
}


 


相关文章
对该文的评论
CSDN 网友 ( 2005-03-21)
应该是DataGridTextBoxColumn
royiw ( 2004-01-10)
找不到类型或命名空间(DataGridColorColumn )???????