使用CF中的Object从函数中获取数据

时间:2014-05-07 10:16:59

标签: coldfusion cfc cfml

我有一个CFC对象和一个能够获取我想要的数据的函数。现在,我想使用该数据并将其提供给已定义的自定义标记属性。当我转储#iEngine.listScore()#时,我得到了一些参数。但我的问题是我应该如何提供属性?

<cfdump var="#iEngine.listScores()#" label="Swapnil Test - Function ListScore">     
<cfset filename="ACE_DataExtract_#DateFormat(now(),'dd.mmm.yyyy')#.xls" />
<!--- Calling Custom tags to create/output xls files --->
<cfmodule template="#request.library.customtags.virtualpath#excel.cfm" file="#filename#" sheetname="ACE Report">

  <cfmodule template="#request.library.customtags.virtualpath#exceldata.cfm"
    query="#iEngine.listScores()#" 
    action="AddWorksheet" 
    sheetname="ACE Report" 
    colorscheme="blue" 
    useheaders="true" 
    contentformat="#{bold=true}#"
    customheaders="#ListScore#">
      <cfoutput>Excel Extract - ACE Report - #DateFormat(Now(),"d-mmm-yyyy")#</cfoutput>
  </cfmodule>   
</cfmodule>

我想在{exceldata'自定义标记中向{Query}属性提供iEngine.listScore()的数据。

以下是iEngine.listScore()

的转储

Dump of iengine.listscore

1 个答案:

答案 0 :(得分:1)

我会编写一个转换数据函数来将你的array-struct更改为一个查询对象,然后将其传递给....

<cffunction name="transformData" result="query">
    <cfargument name="inArray" type="array">

    <cfset local.qryReturn = queryNew("actiondate,actionId,closedate")>
    <!--- You may look up queryNew and also set your dataTypes --->

    <cfloop array="#arguments.inArray#" index="i">
        <cfset QueryAddRow(local.qryReturn)>
        <cfset querySetCell(local.qryReturn,"actionDate",i["actiondate"])>
        <cfset querySetCell(local.qryReturn,"actionid",i["actionid"])>
        <cfset querySetCell(local.qryReturn,"closedate",i["closedate"])>
    </cfloop>

    <cfreturn local.qryReturn>
</cffunction>

<cfset test = [
    {actiondate='1/1/2015',actionid=134,closedate=''},
    {actiondate='1/2/2015',actionid=135,closedate=''},
    {actiondate='1/3/2015',actionid=136,closedate=''}
]>

<cfdump var="#test#">

<cfset resultQry = transformData(test)>
<cfif NOT isquery(resultQry)>
    Exit invalid Data.
<cfelse>
    <cfdump var="#resultQry#">
</cfif>