小编BKK*_*BKK的帖子

ColdFusion - 将查询转换为CFC setter

我正在将旧网站转换为CF 10,并想提出一些我的帮助代码.

代码查看查询,查找我们实例中的内容,并填充它们:

<cffunction name="populateSelf">
    <cfargument name="source" type="query" required="yes" />
    <cfif arguments.source.recordcount EQ 1>
        <cfloop list="#arguments.source.columnlist#" index="local.col">
            <cfif structKeyExists(variables.instance, local.col)>
                <cfset variables.instance[local.col] = arguments.source[local.col]) />
            </cfif>
        </cfloop>
    </cfif> <!--- one record? --->
</cffunction>
Run Code Online (Sandbox Code Playgroud)

我已经structKeyExists(variables.instance, local.col)使用'getMetaData()' 替换了我们当前属性的方便评估,但我在下一行遇到问题:<cfset variables.instance[local.col] = arguments.source[local.col]) />

如果我将其更改为<cfset this[local.col] =arguments.source[local.col] />,则忽略隐式setter并将结果放在此范围内...

为了尝试调用我们的setter,我尝试了这段代码:

<cfset setValue =arguments.source[local.col] />
<cfset evaluate("set#local.col#('#setValue#')" />
Run Code Online (Sandbox Code Playgroud)

但这似乎很复杂且容易出错(必须在字符串中转义任何"'").

使用查询加载部分或全部CFC属性的最佳方法是什么,而不必显式调用this.setPROPERTYNAME(query.COLUMN)可能的几十次????

coldfusion coldfusion-10

6
推荐指数
2
解决办法
384
查看次数

标签 统计

coldfusion ×1

coldfusion-10 ×1