0

我是 ColdFusion 的新手,我正在努力弄清楚如何做一些我可以在 MS Access 中轻松完成的简单功能。

我不断收到错误消息:没有名称为“提交”的方法。此错误仅因表单格式为 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>
4

3 回答 3

1

Dan 提出了一个很好的观点,我最初的答案是基于 HTML 表单,而不是 Flash 表单。所以原来的答案是无效的。但是,我确实发现 ColdFusion 中的 Flash 表单使用的是 ActionScript,而不是 JavaScript。请参阅此处在 Flash 表单中使用 ActionScript的参考。该页面还提到所有表单控件可用于重置或提交表单的自定义 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();"
于 2013-01-02T20:28:52.430 回答
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

于 2013-01-02T22:00:49.140 回答
0

这个,

onchange="submit();"

将会

onchange="this.form.submit();"

如果你有一个 html 表单。我不确定闪存表格。

于 2013-01-02T20:23:16.927 回答