• DevExpress 如何向lookUpEditor中添加新值


    How to Use the ProcessNewValue Event of a LookUp Editor

    Tags:

    Alex Klim (DevExpress)16 years ago

    • How to Use the ProcessNewValue Event of a LookUp Editor

    Leave a Comment

    1 Solution

    Alex Klim (DevExpress)16 years ago

    ​​​​​​​

    The LookUp editor allows a user to enter values which cannot be found in the lookup list. A programmer should handle this situation, otherwise a new value is lost. The LookUp editor provides a ProcessNewValue event for this.

    First of all, you should set the SearchMode property to OnlyInPopup and TextEditStyle to Standard to enable free text entry.

    There are two common approaches for handling the ProcessNewValue event:
    1. Immediately insert the new record in the lookup table and generate a new ID for it.
    2. Display a dialog, where a user can set values for a new data row.

    Below are two code snippets which demonstrate the implementation of these approaches.

    
     

    [C#]Open in popup window

    // solution 1 
    
    private void LookUpEdit1_ProcessNewValue(object sender, DevExpress.XtraEditors.Controls.ProcessNewValueEventArgs e) {
    
       DataRow Row;
    
       RepositoryItemLookUpEdit Edit;
    
       Edit = ((LookUpEdit)sender).Properties;
    
    
    
       if(e.DisplayValue == null || Edit.NullText.Equals(e.DisplayValue) || string.Empty.Equals(e.DisplayValue))
    
           return;
    
    
    
       Row = LookupTable.NewRow();
    
       Row["Name"] = e.DisplayValue;
    
       LookupTable.Rows.Add(Row);
    
       
    
       e.Handled = true;
    
    }
    
    
    
    // solution 2 
    
    private void LookUpEdit1_ProcessNewValue(object sender, DevExpress.XtraEditors.Controls.ProcessNewValueEventArgs e) {
    
       DataRow Row;
    
       RepositoryItemLookUpEdit Edit;
    
       Edit = ((LookUpEdit)sender).Properties;
    
    
    
       if(e.DisplayValue == null || Edit.NullText.Equals(e.DisplayValue) || string.Empty.Equals(e.DisplayValue))
    
           return;
    
           
    
       using(Form2 f = new Form2()) {
    
           f.ItemID = "(Auto Number)";
    
           f.ItemName = e.DisplayValue.ToString();
    
           if(f.ShowDialog(this) == System.Windows.Forms.DialogResult.OK) {
    
               e.DisplayValue = f.ItemName;
    
               Row = LookupTable.NewRow();
    
               Row["Name"] = f.ItemName;
    
               LookupTable.Rows.Add(Row);
    
           }
    
       }
    
           
    
       e.Handled = true;
    
    }
  • 相关阅读:
    导入数据库的命令
    截取字符串
    用decode函数实现行变列
    初始库存入库相关知识
    客户欠款余额账
    存货管理
    创建临时表(转)
    求余额
    学习浪潮系统
    oracle number类型
  • 原文地址:https://www.cnblogs.com/grj001/p/12225304.html
Copyright © 2020-2023  润新知