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. var スコープの変数
  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 に答える