这在之前的许多版本中都运行良好。更新到 ColdFusion 2016 后,cfgrid
尝试将单元格(如项目的活动状态)从 2 更新到 3 时会产生错误。
用户更新单元格并点击回车,然后刷新网格并看到他们的更改未存储。AJAX 记录器的cfdebug
错误是cfgridchanged is undefined
. 关于如何在 ColdFusion 2016 中进行这项工作的任何建议?
<cfgrid name="modify_pids"
height=525
autowidth="yes"
width=1040
vspace=10
selectmode="edit"
insert="No"
delete="No"
format="html"
selectonload = "no"
striperows = "yes"
selectcolor="CDE6F3"
preservePageOnSort="Yes"
pagesize=100
sort=true
onChange="cfc:functions_pids.updatePID({cfgridaction},{cfgridrow}, {cfgridchanged}, '#getcurruser.uid#')"
bind="cfc:functions_pids.getPIDS({cfgridpage},{cfgridpagesize}, {cfgridsortcolumn},{cfgridsortdirection}, '#mygridsortcolumn#', searchPID(), searchDESC(), searchSTAT(), searchMOQ(), searchCOST(), searchUNIT(), searchMODBY(), searchMODDATE() )">
<cfgridcolumn name="PID_ID"
header="PID"
width=40
headeralign="center"
headerbold="Yes"
select="No">
<cfgridcolumn name="Description"
header="Description"
width=150
headeralign="center"
headerbold="Yes"
select="Yes">
<cfgridcolumn name="Active_Status"
header="Status<br>Active=1,3<br>Inactive=2"
width=35
headeralign="center"
headerbold="Yes"
select="Yes"
display="yes">
<cfgridcolumn name="MOQ"
header="MOQ"
width=20
headeralign="center"
headerbold="Yes"
select="Yes">
<cfgridcolumn name="COST"
header="Cost"
width=40
headeralign="center"
headerbold="Yes"
select="Yes">
<cfgridcolumn name="UNIT"
header="Unit"
width=40
headeralign="center"
headerbold="Yes"
select="Yes">
<cfgridcolumn name="Modify"
header="Modified By"
width=50
headeralign="center"
headerbold="No"
select="No">
<cfgridcolumn name="Modify_Date"
header="Modified Date"
width=60
headeralign="center"
headerbold="Yes"
select="No"
type="date">
<cfgridcolumn name="PID_USED"
header="Inventory<br>Instances"
width=50
headeralign="center"
headerbold="No"
select="No">
<cfgridcolumn name="Inventory_Sum"
header="Inventory<br>Total"
width=50
headeralign="center"
headerbold="No"
select="No">
</cfgrid>
functions_pids.cfc 中的部分
<cffunction name="updatePID" access="remote" output="false">
<cfargument name="cfgridaction">
<cfargument name="cfgridrow">
<cfargument name="cfgridchanged">
<cfargument name="getcurruser"> <!--- pass in modified by user id --->
<cfargument name="PID_ID" required="no" type="string" default="" >
<cfset strctKey=StructKeyArray(cfgridchanged) />
<cfset strctVal=StructFindKey(cfgridchanged, strctKey[1]) />
<cfset strctVal=strctVal[1] />
<cfif cfgridaction is "D">
<cfelseif cfgridaction is "U">
<cfquery name="update" datasource="#request.dbname#" username="#request.dbuser#" password="#request.dbpw#">
UPDATE PIDS
SET #strctKey[1]# = '#strctVal.value#',
Modify = '#getcurruser#',
Modify_Date = '#dateformat(CreateODBCDateTime( Now()), "mm/dd/yyyy")#'
WHERE PID_ID = '#cfgridrow.PID_ID#'
</cfquery>
<cfelseif cfgridaction is "I">
</cfif>
<cfreturn />
</cffunction>