0
這對許多版本之前工作正常。在更新到ColdFusion 2016之後,在嘗試將活動狀態從2更新爲3時,會產生錯誤。問題與ColdFusion 2016 CFGrid更新功能
用戶更新單元格並命中輸入,然後刷新網格並看到它們的更改沒有存儲。來自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>
沒有你所申請到更新時,這打破了?我知道Adobe幾天前剛剛發佈了另一個更新。該更新包含對CFGrid的一些更改以及AJAX功能。 [在ColdFusion(2016年發佈)更新5中修復的錯誤](https://helpx.adobe.com/coldfusion/kb/bugs-fixed-coldfusion-2016-update-5.html#bugsfixed) –
Miguel - update 5最近應用並解決問題 – Brian
太棒了!很高興爲您解決它。我會補充說,作爲答案,其他人會更清楚地看到它。 –