首页 > 解决方案 > 如何根据Angular 6同一行中的其他单元格值在AG-Grid选择下拉列表中加载不同的选项?

问题描述

我在列定义中使用以下代码:

 { headerName: 'Part', field: 'part', 
    cellStyle: {'background-color': 'cyan'}, editable: true, 
    cellEditor:'agSelectCellEditor', cellEditorParams: 

我在网格中有其他列 ex-

   { headerName: 'Colour', field: 'colour', 
    cellStyle: {'background-color': 'cyan'}, editable: true, 
    cellEditor:'agSelectCellEditor', cellEditorParams: function(params) { 
    var selectedPart = params.data.type; if (selectedPart==='R&S') { 
    return { values: this.partTypeListRS }; } else if(selectedPart==='WiFi') 
    { return { values: this.partTypeListWifi }; } else 
    if(selectedPart==='Other') { return { values: this.partTypeListOther }; 
    }}},
    }

我收到错误无法读取未定义的 this.partTypeListRS 属性,如果我单击满足 selectedPart==='R&S' 条件并分别满足所有其他条件的行。

标签: angularangular6ag-gridag-grid-angular

解决方案


您可以cellEditorParams以根据另一列的值返回不同值的方式定义函数。

这是来自 ag-grid 网站的示例 -

cellEditor : 'agSelectCellEditor';
cellEditorParams: function(params) {
    var selectedCountry = params.data.country;
    if (selectedCountry==='Ireland') {
        return {
            values: ['Dublin','Cork','Galway']
        };
    } else {
        return {
            values: ['New York','Los Angeles','Chicago','Houston']
        };
    }
}

看看官方文档中的这个例子


推荐阅读