Ответ 1
Вы также можете попробовать listToArray, а затем использовать конструкцию for-in для массивов в CF9 как:
<cfscript>
aCol = listToArray (qry.ColumnList);
for( fieldName in aCol ){
form[fieldName] = qry[fieldName][1];
}
</cfscript>
Страница 116 руководства разработчика "В отличие от тега cfloop, петли for-in CFScript не обеспечивают встроенную поддержку для циклирования запросов и списков".
Q: Как мне перебирать список с помощью нового синтаксиса script в ColdFusion 9?
<cfloop list="#qry.Columnlist#" index="FieldName">
<cfset form[FieldName] = qry[FieldName][1]>
</cfloop>
Вы также можете попробовать listToArray, а затем использовать конструкцию for-in для массивов в CF9 как:
<cfscript>
aCol = listToArray (qry.ColumnList);
for( fieldName in aCol ){
form[fieldName] = qry[fieldName][1];
}
</cfscript>
<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>
Версия EDIT 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>
Я сначала включил список в массив. ListGetAt()
неэффективно вызывать n раз в цикле. ArrayLen()
однако должен быть довольно быстрым.
<cfscript>
arr = ListToArray(qry.Columnlist);
for (i = 1; i <= ArrayLen(arr); i++)
{
fieldName = arr[i];
form[FieldName] = qry[FieldName][1];
}
</cfscript>