开发人员指南的第116页说 “与cfloop标记不同,CFScript for-in循环不提供内置支持来循环查询和列表。”
问:如何使用ColdFusion 9中的新脚本语法循环遍历列表?
<cfloop list="#qry.Columnlist#" index="FieldName">
<cfset form[FieldName] = qry[FieldName][1]>
</cfloop>
答案 0 :(得分:19)
您也可以尝试使用listToArray,然后在CF9中使用for-in for Arrays作为:
<cfscript>
aCol = listToArray (qry.ColumnList);
for( fieldName in aCol ){
form[fieldName] = qry[fieldName][1];
}
</cfscript>
答案 1 :(得分:12)
<cfscript>
var i = 0;
var l = ListLen(qry.Columnlist);
var FieldName = "";
for (i = 1; i lte l; i = i + 1) // you also can use i++ instead
{
FieldName = ListGetAt(qry.Columnlist, i);
form[FieldName] = qry[FieldName][1];
}
</cfscript>
编辑Nicer(可能更快,对于非常重的循环)以上版本:
<cfscript>
var i = 0;
var Fields = ListToArray(qry.Columnlist);
var FieldName = "";
var l = arrayLen(Fields);
for (i = 1; i lte l; i = i + 1) // you also can use i++ instead
{
FieldName = Fields[i];
form[FieldName] = qry[FieldName][1];
}
</cfscript>
答案 2 :(得分:5)
我会先将列表转换为数组。 ListGetAt()
在循环中被调用n次效率不高。 ArrayLen()
但是应该很快。
<cfscript>
arr = ListToArray(qry.Columnlist);
for (i = 1; i <= ArrayLen(arr); i++)
{
fieldName = arr[i];
form[FieldName] = qry[FieldName][1];
}
</cfscript>