私は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