评估功能

时间:2010-01-06 19:02:10

标签: coldfusion cfloop

有没有更好的方法来编写以下内容?

<cfloop list="#qry.Columnlist#" index="FieldName">
   <cfset "form.#FieldName#" = Evaluate("qry.#FieldName#")>
</cfloop>

此循环将查询中的每个字段分配给相应的表单字段。 我理解评估功能是避免的。

3 个答案:

答案 0 :(得分:11)

<cfloop list="#qry.Columnlist#" index="FieldName">
    <cfset form[FieldName] = qry[FieldName][1]>
</cfloop>

答案 1 :(得分:4)

假设您正在返回单个记录集,则以下内容将起作用。

<cfloop list="#qry.Columnlist#" index="FieldName">
<cfset "form.#FieldName#" = qry[FieldName][1]>
</cfloop>

答案 2 :(得分:1)

切向,但是如果循环遍历查询的多行,则可以使用查询对象中的currentRow变量执行与接受的答案相同的操作。

<cfset var someStruct = {} />
<cfset var colummnList = queryObj.columnList />

<cfloop query="queryObj">
    <cfset someStruct[currentRow] = {} />        

    <cfloop list="#columnList#" index="fieldName">
        <cfset someStruct[currentRow][fieldName] = queryObj[fieldName][currentRow] />
    </cfloop>
</cfloop>