我有一个引用参数“Year_Parameter”的值提示,以及一个包含一列(数据项表达式)的列表,它以这种方式引用与值提示相同的参数:
#prompt('Year_Parameter')#
值提示有一些静态选择:2011、2012 和 2013。因此,当我运行我的报表,并在显示报表页面之前弹出的提示页面中输入 2012 时,在值提示中自动选择了 2012 从其显示报告页面时的选项列表。
此外,如果我将 2012 放在默认选择列表中,则不会显示任何提示页面,并且现在在显示报告时也自动选择了 2012 作为值提示。
但是,如果我从默认选择列表中删除 2012,并将我的数据项表达式更改为以下任一表达式:
#prompt('Year_Parameter', 'token', '2012')#
#prompt('Year_Parameter', 'token', 2012)#
#prompt('Year_Parameter', 'string', 2012)#
#prompt('Year_Parameter', 'string', '2012')#
... 没有弹出提示页面,当 2012 被指定为默认选择时,但没有为值提示自动选择值。值提示显示其默认标题文本:参数名称 - Year_Parameter"。
记住提示函数定义:
提示( prompt_name , datatype , defaultText , text , queryItem , trailing_text )
任何人都知道为什么会发生这种情况,更重要的是如何通过在数据项表达式中指定它来选择值提示的默认选择的解决方案?
是不是因为prompt() 宏只尝试获取参数'Year_Parameter' 的值,但它本身并没有用值填充参数?该参数必须由某个值提示给出(在提示页面上或嵌入在报表页面中)。
因此,提示函数的 defaultText 参数永远不会填充参数本身,而是在参数没有(有效)值的情况下由这个特定的提示函数返回?
非常感谢您的任何意见!
编辑:找到有关如何为参数动态分配默认值的说明。
http://cognosknowhow.blogspot.no/2013/04/how-to-dynamically-set-up-default-value.html
最后:我最终使用以下 Javascript 来动态选择值提示并更新报告:
<script type="text/javascript">
// This function updates the report dynamically for the current year
// The function is wrapped inside a setTimeout call in order to avoid an error caused by too frequent requests
setTimeout(function updatePrompt() {
var oCR = cognos.Report.getReport("_THIS_");
var yearPrompt = oCR.prompt.getControlByName("YearPrompt");
var selectedValue = yearPrompt.getValues()[0];
if (typeof selectedValue === "undefined") {
currentYear = new Date().getFullYear();
yearPrompt.setValues([{'use':currentYear}]);
// Update report
oCR.sendRequest(cognos.Report.Action.FINISH);
}
}, 50);
</script>