我有一个1.5角应用程序正在使用power bi嵌入式js库来实例化高级过滤器,然后通过setFilters()函数将其应用于嵌入式报告:
reportsCtrl.js
function onEmbedded(report) {
vm.embededReport = report;
if (vm.activeFilter) {
vm.embededReport.setFilters([vm.activeFilter]);
}
}
function buildFilter() {
var date1 = new Date(vm.selectedDate.toDateString());
var date2 = new Date(date1);
//add one day via mutator setDate function
date2.setDate(date1.getDate() + 1);
vm.activeFilter = new pbi.models.AdvancedFilter(
{
table: 'tblMessage',
column: 'event_timestamp'
},
'And',
[{
operator: 'GreaterThanOrEqual',
value: date1
},
{
operator: 'LessThan',
value: date2
}]
);
if (vm.embededReport) {
vm.embededReport.setFilters([vm.activeFilter]);
}
}
function loadReport(reportId) {
vm.reportConfig = null;
reportService.getReport(reportId, facilityId).then(function (response) {
//merge report with default configurations
vm.reportConfig = angular.merge({}, defaultReportConfig, response);
});
}
reports.tpl.html
<h1>{{vm.message}}</h1>
<div ng-repeat="report in vm.reports">
<pre>{{report | json}}</pre>
<button ng-click="vm.loadReport(report.id)">embed</button>
</div>
<button ng-click="vm.buildFilter()">
Add Filter
</button>
<h2>Acitve Filter!</h2>
<pre>{{vm.activeFilter | json}}</pre>
<div>
<powerbi-component ng-if="vm.reportConfig" options="vm.reportConfig" on-embedded="vm.onEmbedded($embed)" ></powerbi-component>
</div>
应用过滤器时出现以下3个错误。
&#34; .operator无效。不符合要求的约束&#34;
&#34; .conditions.0.value无效。不符合类型约束&#34;
&#34;过滤器无效&#34;
从documentation判断,虽然我认为我的过滤器结构正确......任何想法?我觉得我想念的东西很小......
答案 0 :(得分:1)
我最终能够弄清楚这一点。在这里发布答案,以防它帮助其他人。来自powerbi嵌入式库的过滤器对象的日期必须格式如下:
&#34; 2016-12-01T18:52:11.148Z&#34;
使用javascript日期对象.toISOString()或.toJSON()可以解决问题。