0

我有一个具有远程功能的 CFC,并试图将其填充到我的 cfm 页面的 cfselect 元素中。但我在选择中没有得到任何东西。

我尝试直接执行cfc,但我调用的方法没有执行。

这是 CFC 的代码:

    <cfcomponent output="false">
        <cffunction name="getYear" access="remote" returnType="query">

            <cfset yearlist = QueryNew("yr","integer")>
            <cfset temp = QueryAddRow(yearlist,3)>
            <cfset counter = 1>
            <cfloop from="#evaluate(year(Now())-1)#" to="#evaluate(year(Now())+1)#" index="y">
                <cfset temp = QuerySetCell(yearlist,"yr",y,counter)>
                <cfset counter = counter + 1>
            </cfloop>

            <cfreturn yearlist>
        </cffunction>
</cfcomponent>

这是 CFM 的代码

    <body>

    <cfform>

    <table>
        <tr>
            <td>Select Year:</td>
            <td><cfselect name="yearval"
                        bind="cfc:cfc.ajaxcomp.getYear()"
                        value="yr"  
                        display="yr"
                        bindonload="true" /></td>
        </tr>
    </table>

    </cfform>

</body>

你能告诉我我在这里错过了什么吗?

谢谢!

4

1 回答 1

1

所以下面的代码对我有用。我改变了一些东西,很难知道它做了什么,但是:

  1. 变量范围的变量
  2. 消除了一些复杂性
  3. 将查询列从整数更改为 varchar

-

<cfcomponent output="false">
    <cffunction name="getYear" access="remote" returnType="query">

        <cfset var y = 0 />
        <cfset var yearList = QueryNew("yr","varchar")>

        <cfloop from="#year(Now())-1#" to="#year(Now())+1#" index="y">
            <cfset queryAddRow(yearList) />
            <cfset QuerySetCell(yearList,"yr",y)>
        </cfloop>

        <cfreturn yearlist>
    </cffunction>
</cfcomponent>
于 2009-09-01T18:43:19.430 回答