我是ColdFusion的新手,我正在努力弄清楚如何在MS Access中轻松完成一些简单的功能。
我一直收到错误:没有名为'submit'的方法。仅出现此错误,因为表单格式为flash。
非常感谢任何帮助。
<html>
<cfparam name="form.state" default="">
<cfparam name="form.lastname" default="">
<!---Grid Source--->
<cfquery name="getArtists" datasource="cfartgallery">
SELECT A.*
FROM ARTISTS A
WHERE
1=1
AND STATE like <cfqueryparam value="%#form.state#%" cfsqltype="CF_SQL_VARCHAR" maxlength="255">
AND LASTNAME like <cfqueryparam value="%#form.lastname#%" cfsqltype="CF_SQL_VARCHAR" maxlength="255">
ORDER BY A.LASTNAME, A.FIRSTNAME
</cfquery>
<head>
</head>
<body style="padding:20px;">
<cfform action="TEST.cfm" method="post" format="flash">
<cfformgroup type="horizontal" style="backgroundAlpha:0;font-size:12;color:##000;">
<cfformgroup type="vertical" width="100">
<!---Query for STATE--->
<cfquery name="getState" datasource="cfartgallery">
SELECT A.STATE
FROM ARTISTS A
WHERE
1=1
AND LASTNAME like <cfqueryparam value="%#form.lastname#%" cfsqltype="CF_SQL_VARCHAR" maxlength="255">
</cfquery>
<!---STATE Dropdown--->
<cfselect name="state" query="getState" queryposition="below"
label="State:"
value="STATE"
display="STATE"
required="no"
selected="#form.state#"
onchange="submit();"
style="backgroundAlpha:0;" width="125">
<option></option>
</cfselect>
</cfformgroup>
<cfformgroup type="vertical" width="100">
<!---Query for LastName--->
<cfquery name="getLast" datasource="cfartgallery">
SELECT A.LASTNAME
FROM ARTISTS A
WHERE
1=1
AND STATE like <cfqueryparam value="%#form.state#%" cfsqltype="CF_SQL_VARCHAR" maxlength="255">
</cfquery>
<!---LastName Dropdown--->
<cfselect name="lastname" query="getLast" queryposition="below"
label="Last Name:" value="LASTNAME" display="LASTNAME"
selected="#form.lastname#"
required="no"
onchange="submit();"
style="backgroundAlpha:0;" width="125">
<option></option>
</cfselect>
<a href="TEST.cfm"><input type="button" value="Reset"></a>
</cfformgroup>
</cfformgroup>
<cfformitem type="spacer" height="20"/>
<!---Grid--->
<cfgrid name="myGrid" query="getArtists" format="html">
<cfgridcolumn name="ARTISTID" header="ARTISTID" width="75" headeralign="center" dataalign="center"/>
<cfgridcolumn name="FIRSTNAME" header="FIRSTNAME" width="100" headeralign="center" dataalign="center"/>
<cfgridcolumn name="LASTNAME" header="LASTNAME" width="75" headeralign="center" dataalign="center"/>
<cfgridcolumn name="ADDRESS" header="ADDRESS" width="100" headeralign="center" dataalign="center"/>
<cfgridcolumn name="CITY" header="CITY" width="125" headeralign="center" dataalign="center"/>
<cfgridcolumn name="STATE" header="STATE" width="125" headeralign="center" dataalign="center"/>
<cfgridcolumn name="POSTALCODE" header="POSTALCODE" headeralign="center" dataalign="center"/>
<cfgridcolumn name="EMAIL" header="EMAIL" width="125" headeralign="center" dataalign="center"/>
<cfgridcolumn name="PHONE" header="PHONE" headeralign="center" dataalign="center"/>
<cfgridcolumn name="FAX" header="FAX" headeralign="center" dataalign="center"/>
<cfgridcolumn name="THEPASSWORD" header="THEPASSWORD" headeralign="center" dataalign="center"/>
</cfgrid>
</cfform>
</body>
</html>
答案 0 :(得分:1)
Dan提出了一个很好的观点,我的原始答案基于HTML表单,而不是Flash表单。所以原来的答案是无效的。但是,我确实发现ColdFusion中的Flash表单使用的是ActionScript,而不是JavaScript。请参阅此处的参考Using ActionScript in Flash forms。该页面还提到,可用于重置或提交表单的所有表单控件的自定义ActionScript函数为resetForm()
和submitForm()
。因此,请尝试将onchange
事件从submit();
更改为submitForm()
,如下所示:
onchange="submitForm()"
我不知道ActionScript是否需要分号。
* ---历史目的下面的原始答案--- *
你没有说你何时收到错误“没有名字'提交'的方法。”查看您提供的代码我假设您从表单的状态或姓氏下拉框中选择某些内容时会出现错误。当这些选择中的任何一个发生变化时,您是否尝试提交表单?如果我的假设是正确的,那么您可以尝试给表单id
,然后对您的提交声明进行限定。像这样:
为您的表单id
<cfform id="yourformid" action="TEST.cfm" method="post" format="flash">
限定您的提交声明
<cfselect ...
onchange="document.getElementById("yourformid").submit();"
答案 1 :(得分:1)
不会生成HTML表单。因此,您无法使用JavaScript / DOM
注意:<cfsavecontent>
内的所有内容都是ActionScript:
<cfsavecontent variable="astest">
if(_global.arrMembers == undefined) _global.arrMembers = data.dataProvider.slice(0);
var arrMembers = _global.arrMembers;
var arrDisplay:Array = [];
for(var i = 0; i < arrMembers.length; i++)
{
if(arrMembers[i].dept == myselect1.value || myselect1.value == 'All')
{
arrDisplay.push(arrMembers[i]);
}
}
data.dataProvider = arrDisplay;
</cfsavecontent>
然后:
<cfselect ... onChange="#astest#">
参考: http://www.asfusion.com/examples/item/filtering-records-on-a-cfform-grid
答案 2 :(得分:0)
这,
onchange="submit();"
将是
onchange="this.form.submit();"
如果您有html表单。我不确定flash表单。