DevExpress控件 DataGrid 单元格编辑 回车

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using CYSoft.UI.Common;
using CYSoft.Common;
using CYSoft.TS.EntityLib;
using CYSoft.IC.Common.A0;
//Dev 引用
using DevExpress.XtraEditors;
using DevExpress.XtraEditors.Repository;

namespace CYSoft.TS.UI.BookInfo
{
    public partial class FrmCellEdit : TS.UI.Common.FrmEditBase
    {
        //接口
        public IC.BookInfo bb = null;
        public FrmCellEdit()
        {
            InitializeComponent();

            bb = new IC.BookInfo();

            InitCtl();

        }

        /// <summary>
        /// 初始化
        /// </summary>
        public void InitCtl() {
            //克隆表结构 绑定到grid
            DataTable dt = b.BookGetByCode("").Tables[0].Clone();
            grid.DataSource = dt;

            //自定义方法 初始化 gv
            CYSoft.UI.Common.Function.InitGrid(this.gv,
                new string[] {"编码","名称" },
                new string[] {"BookNo","BookName" },
                new int[] {100,100 });

            //编辑列  设置
            RepositoryItemTextEdit rite = new RepositoryItemTextEdit();
            //keydown事件
            rite.KeyDown+=new KeyEventHandler(rite_KeyDown);
            gv.Columns["BookNo"].ColumnEdit = rite;

            gv.CellValueChanged += new DevExpress.XtraGrid.Views.Base.CellValueChangedEventHandler(gv_CellValueChanged);
            gv.InitNewRow += new DevExpress.XtraGrid.Views.Grid.InitNewRowEventHandler(gv_InitNewRow);
        }

        /// <summary>
        /// 单元格回车
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        void rite_KeyDown(object sender, KeyEventArgs e) {
            //用户点击 回车
            if (e.KeyCode == Keys.Enter) {
                TextEdit te = sender as TextEdit;
                //值为空时返回
                if (te == null || string.IsNullOrEmpty(te.Text.Trim())) {
                    return;
                }              

                //自定义方法,根据用户输入内容从数据库获取数据
                DataSet ds = bb.BookGetByCode(te.Text.Trim());
                //有数据记录
                if (ds.Tables[0].Rows.Count > 0) {
                    //初始化DataRow  值为 第一行数据
                    DataRow dtBook = ds.Tables[0].Rows[0];
                    //初始化DataRow  值为
                    DataRow dr = gv.GetDataRow(gv.FocusedRowHandle);
                    foreach (DataColumn dc in dr.Table.Columns) {
                        dr[dc.ColumnName] = dtBook[dc.ColumnName].ToString();
                    }
                    //终止行编辑
                    dr.EndEdit();
                    //调用方法
                    SetCellEdit(gv.FocusedRowHandle);
                    //自定义类 对gv的一些设置
                    CYSoft.TS.UI.Common.TSFunc.SetBestFitColumns(gv);
                }

            }

        }

        /// <summary>
        /// 单元格处理
        /// </summary>
        /// <param name="row"></param>
        private void SetCellEdit(int row)
        {
            Application.DoEvents();
            try
            {
                gv.BeginInit();
                grid.Focus();
                gv.Focus();
                gv.SelectCell(row, gv.Columns["BookNo"]);
                gv.FocusedColumn = gv.Columns["BookNo"];
                gv.ShowEditor();
            }
            finally
            {
                gv.EndInit();
            }
        }

        /// <summary>
        /// 单元格 焦点离开 触发该事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        void gv_CellValueChanged(object sender, DevExpress.XtraGrid.Views.Base.CellValueChangedEventArgs e)
        {
            if (e.Column.FieldName == "BookNo")
            {
                if (e.Value == null)
                    return;
            }
        }

        void gv_InitNewRow(object sender, DevExpress.XtraGrid.Views.Grid.InitNewRowEventArgs e)
        {
            SetCellEdit(e.RowHandle);
        }

        /// <summary>
        /// 增加新行
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnNewLine_Click(object sender, EventArgs e)
        {
            DataTable dt = grid.DataSource as DataTable;
            if (dt == null)
                return;

            gv.AddNewRow();
        }
    }
}

时间: 2024-10-14 04:52:57

DevExpress控件 DataGrid 单元格编辑 回车的相关文章

MFC List Control控件添加单元格编辑和单元格下拉列表项以适用于数据库相关操作

作为现代的软件,往往是连着数据库的,而连着和用户方便地操作之间,还有着界面这道坎.MFC是Windows上比较好开发用户界面的框架,然而其自带的控件中没有对于数据库表格支持较好的控件,而使用网上提到的 DataGrid 等控件在本人的win8.1+VS2013平台上老出现找不到控件或者头文件的问题,搞的烦死人.最后想到 List Control 控件只要稍作修改,加上单元格编辑和单元格下拉列表,其实就能和数据库进行良好的对接,一百度,果然有人已经做了这件事,实在是太让人感动了!       

DataGridView控件选中单元格、直接在控件中修改信息

                                                           原文取自个人博客:www.jycoder.com欢迎访问 一,获取DataGridView控件中的当前单元格 若要与DataGridView进行交互,通常要求用编程的方式发现哪个单元格出于活动状态.如果需要更改单元格,可通过DataGridView控件的CurrentCell属性来获取当前单元格的信息: 语法如下: Public DataGridViewCell CurrentC

c#winform中如何修改ListView控件每个单元格的颜色

ListView在View属性为Details的时候它呈现的方式和DataGirdView差不多,它的每一行都是一个ListViewItem,然而每个ListViewItem都有一个BackColor的属性,但是设置了这个属性却没有任何作用.因为是ListView的每一行的样式都继承的父控件的样式所以无法改变. 解决方案: ListViewItem item; item = new ListViewItem(new string[] { "NAME","" });

DevExpress 控件 DataGrid常见用法

刚接触DevExpress第三方控件,把DataGrid的常见用法整理一下,以供参考: 说明: gcTest   GridControl gvText    GridView <span style="font-size:14px;"> DataTable dt=new DataTable ();//绑定 gcTest.DataSource = dt; //隐藏最上面的GroupPanel gvText.OptionsView.ShowGroupPanel = false;

Dev控件GridView单元格绑定控件

//文本按钮 RepositoryItemButtonEdit btnFields = new RepositoryItemButtonEdit();//创建控件 btnFields.ButtonClick += new DevExpress.XtraEditors.Controls.ButtonPressedEventHandler(btnField_ButtonClick);//事件绑定 gridView1.Columns["Fields"].ColumnEdit = btnFie

JQuery easyui datagrid 单元格编辑时,使用浮动的textarea文本框并进行数据校验

有两种方式实现,一种方式是在html中验证,一种方式是在js中进行验证 方式一: <th data-options="filed:'remark',width:200,editor:{type:'textarea'}">备注</th> 方式二: <th data-options="filed:'remark',width:200,editor:{type:'textarea', options:{validType:'maxLength[150]

list contro控件根据单元格的内容改变显示的颜色

第一首先向控件添加NM_CUSTOMDRAW消息.过程如下: 在头文件中添加: afx_msg void OnCustomdrawMyList(NMHDR *pNMHDR, LRESULT *pResult); 为消息NM_CUSTOMDRAW的响应函数 在.CPP文件中添加 BEGIN_MESSAGE_MAP(CListControlDlg, CDialog) //{{AFX_MSG_MAP(CListControlDlg) ON_WM_SYSCOMMAND() ON_WM_PAINT() O

easyui datagrid 单元格编辑保存

要求分数和排序两列能编辑 //查询该试卷题型的试题 $('#allList1').datagrid({ url:app.approot+"paperRes/getPaperQuestionList/"+ptyid, handler:function(){ //接受改变的值 $('#allList1').datagrid('acceptChanges'); }, onBeforeEdit: function (rowIndex,rowData) { $("#selQuestio

easyui datagrid 单元格编辑 即见即所得,MVC菜单维护,扫描增加

效果如图: 参见 EasyUI 官方 Demo 及文档 @{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml"; } <script src="~/jquery-easyui-1.4.2/locale/easyui-lang-zh_CN.js"></script> <table id="datagrid" class