3

私はag-gridでAngular 1.xを使用しています。まず第一に、エンタープライズ機能を有効にする方法がわかりません。エンタープライズの購入を計画しており、現在評価中ですが、サポートはかなり弱いです。

今、ElasticSearch からグリッドにデータをフィードしようとしている実際の問題です。ag-grid のデモのようにシミュレートしようとしています。ページサイズを変更すると、ES サーバーからデータが取得され、新しいページサイズの新しいデータセットがグリッドに供給されます。そのために、グリッドを更新しようとすると、任意のアクションで $scope.gridOptions.api.setRowData(data) を使用しています。つまり、setRowData です。「メソッドが未定義です」というエラーが表示されます。ページをロードするときに初めて機能します。

この問題を解決するにはどうすればよいですか? 何か不足していますか?

関数: これは、$scope.gridOptions.api.setRowData(data) を呼び出す関数であり、エラーが発生しています

「キャッチされていない TypeError: 未定義のプロパティ 'setRowData' を読み取ることができません」

function displayGrid(fromDate, toDate, fieldNameArray, affiliate, product,consmb, region, customer, page, pageSize)
  {

   // Constructing Query from dashboard input
        var gridQuery = globalFiltersDrillDown(fromDate, toDate, fieldNameArray, page, pageSize);
        var finalGridQuery = buildQueryForDrillQuery(affiliate,product, consmb, region, customer, gridQuery, "" , false);
        console.log("final Query :" + JSON.stringify(finalGridQuery));
       var data =[];

    setTimeout(function ()
    {
       esClientIndirect.search
          (
            {
              index: esIndex1,
              type: esType1,
              size : pageSize,
              from : page,
              body: finalGridQuery
            },
            function (error, response, status)
            {
              $scope.numberOfRecords = numberCommas(response.hits.total);
              if(error)
              {
                $scope.error = "Error : " + status ;
              }
              else
              {
                var startBrace = "{ ";
                var endBrace = " }"
                data.length = 0;
                var k = 0;
                for(var o in response.hits.hits)
                {
                  var dataFields = response.hits.hits[o].fields;
                  var numberOfElements = fieldNameArray.length -1;
                  var row = startBrace;
                  for (var i in dataFields)
                  {
                    var columnName = fieldNameArray[k];
                    var columnValue =  dataFields[columnName];
                    if (k == numberOfElements)
                    {
                      row += (" \"" + columnName +"\" : \"" + columnValue +"\"");
                    }
                    else
                    {
                      row += (" \"" + columnName +"\" : \"" + columnValue +"\",");
                    }
                    k = k+1;
                  }
                  row += endBrace;
                  k =0;
                  data.push(JSON.parse(row));
                }
                // pushing data into the ag-grid
                setTimeout(function()
                {
                  $scope.gridOptions.api.setRowData(data);
                }, 200);
            }
            }, 100); // end of elastic search call back
            }); // end of elastic search set time out call back
4

1 に答える 1

0

このエラーは、API が存在しないことを示しています。この呼び出しを行う前に、$scope.gridOptions をインスタンス化したことを確認しましたか?

于 2016-04-21T18:11:39.013 に答える