阅读:1665 回复:4
实名用户_3ebdbeed
4

帖子

9

跟帖

137

积分

初级榴莲
初级榴莲

子表动态添加数据项

楼主#
更多 发布于:2019-01-24 15:05
前端代码:

 <SheetControls:SheetSubTable ID="SheetSubTable_ATLECNDispo" runat="server" DataField="ATLECNDispo"
                                        OnEditorInitializing="SheetSubTable_ATLECNDispo_EditorInitializing"
                                        OnEditorSaving="SheetSubTable_ATLECNDispo_EditorSaving"
                                        OnEditorLoading="SheetSubTable_ATLECNDispo_EditorLoding" />


SheetSubTable_ATLECNDispo_EditorInitializing(添加的事件)
后台代码

     protected void SheetSubTable_ATLECNDispo_EditorInitializing(object sender, OThinker.H3.WorkSheet.EditorInitializingEventArgs e)
        {





                DropDownList list = new DropDownList();
          
                list.Items.Add("已下采购订单给供应商中");
                list.Items.Add("库存");
                list.Items.Add("产线中");
                list.Items.Add("成品");
                list.Items.Add("已经出货");
                e.Control = list;
               //如何添加到 SheetSubTable_ATLECNDispo ?
              
            }
有在后台代码执行,
但是数据项没有对应的添加上去,
武汉技术支持团队
40

帖子

1181

跟帖

3860

积分

论坛版主
论坛版主
1楼#
发布于:2019-01-25 09:31
你这个应该是8.2版本的代码吧,找了一个例子,参考一下

 protected void tab_BOMProductDetail_EditorLoading(object sender, EditorLoadingEventArgs e)
        {
            var cell = e.Control as TableCell;
            if (Enviroment.ActivityTemplate != null)
            {
                if (Enviroment.ActivityTemplate.DisplayName == "提交BOM单")
                {
                    if (e.CurrentRow.RowType == DataControlRowType.DataRow)
                    {
                        if (e.ColumnName == "新品种信息")
                        {
                            var cbx = new CheckBox();
                            cbx.Attributes.Add("onclick", "erpchange(this);");
                            bool result = false;
                            Boolean.TryParse(e.Value.ToString(), out result);
                            cbx.Checked = result;
                            cell.Controls.Add(cbx);
                            e.Set = true;
                        }


                        if (e.ColumnName == "品名")
                        {
                            var txtproduct = new SheetTextBox();
                            txtproduct.ID = "txtname";
                            txtproduct.Attributes.Add("style", "width:90%");
                            txtproduct.Text = e.Value.ToString();
                            txtproduct.Attributes.Add("lang", "requiredfield");
                            //txtproduct.Attributes.Add("onclick", " $.Geterppacking(this, 'Geterppacking');");
                            cell.Controls.Add(txtproduct);
                            e.Set = true;
                        }
                        if (e.ColumnName == "ERP产品编码")
                        {
                            var dv = e.CurrentRow.DataItem as DataRowView;
                            string ischeck = dv["新品种信息"].ToString();


                            var txtproduct = new SheetTextBox();
                            txtproduct.ID = "txtcode";
                            txtproduct.Text = e.Value.ToString();
                            txtproduct.Attributes.Add("style", "width:90%");
                            if (ischeck != "True")
                            {
                                txtproduct.Attributes.Add("lang", "requiredfield");
                            }
                            txtproduct.Attributes.Add("onclick", " $.Geterppacking(this, 'Geterpproduct');");
                            cell.Controls.Add(txtproduct);
                            e.Set = true;
                        }


                        if (e.ColumnName == "剂型")
                       {
                           var drptype = new DropDownList();


                           drptype.Items.Add(new ListItem { Value = "软糖", Text = "软糖" });
                           drptype.Items.Add(new ListItem { Value = "固体制剂", Text = "固体制剂" });
                           drptype.Items.Add(new ListItem { Value = "软胶囊", Text = "软胶囊" });
                           drptype.Items.Add(new ListItem { Value = "口服液", Text = "口服液" });
drptype.Items.Add(new ListItem { Value = "化妆品", Text = "化妆品" });
                           drptype.SelectedValue = e.Value.ToString();
                           cell.Controls.Add(drptype);


                           e.Set = true;
                       }
                    }
                }
            }


            //ScriptManager.RegisterStartupScript(UpdatePanel1, this.Page.GetType(), "", "loadchange();", true);
        }
实名用户_3ebdbeed
4

帖子

9

跟帖

137

积分

初级榴莲
初级榴莲
2楼#
发布于:2019-01-26 11:03
武汉技术支持团队:你这个应该是8.2版本的代码吧,找了一个例子,参考一下

 protected void tab_BOMProductDetail_EditorLoading(object sender, EditorLoadingEventArgs e)...
回到原帖
   protected void SheetSubTable_ATLECNDispo_EditorInitializing(object sender, OThinker.H3.WorkSheet.EditorInitializingEventArgs e)
        {

            var cell = e.Control as TableCell;
            if (e.ColumnName.ToUpper() == "MATERIAL_STATUS")
            {
                DropDownList list = new DropDownList();
                /*
                list.Items.Add("ON ORDER");
                list.Items.Add("IN STORE");
                list.Items.Add("WORKING PROCESS");
                list.Items.Add("FINISHED GOODS");
                list.Items.Add("IN FIELD");
                 */
                //list.Items.Add("已下采购订单给供应商中");
                //list.Items.Add("库存");
                //list.Items.Add("产线中");
                //list.Items.Add("成品");
                //list.Items.Add("已经出货");
                //e.Control = list;

                //数据绑定不了,用下面这个方法

                list.Items.Add(new ListItem { Value = "已下采购订单给供应商中", Text = "已下采购订单给供应商中" });
                list.Items.Add(new ListItem { Value = "库存", Text = "库存" });
                list.Items.Add(new ListItem { Value = "产线中", Text = "产线中" });
                list.Items.Add(new ListItem { Value = "成品", Text = "成品" });
                list.Items.Add(new ListItem { Value = "已经出货", Text = "已经出货" });
                cell.Controls.Add(list);
                e.Set = true;
              
              
            }

我改了下,最后的这句 e.Set = true;  提示错误      Set是一个“方法组” 无法为它赋值
武汉技术支持团队
40

帖子

1181

跟帖

3860

积分

论坛版主
论坛版主
3楼#
发布于:2019-01-29 09:41
if (e.CurrentRow.RowType == DataControlRowType.DataRow)
                    {
}

加上这个判断试试
小高德生科技
4

帖子

7

跟帖

124

积分

初级榴莲
初级榴莲
4楼#
发布于:2019-03-11 10:29
可以在前端js加DropDownList的绑定数据项不
游客

返回顶部