我正在对一些基本形式进行线框设计,但遇到了意想不到的405 Method Not Allowed障碍。
基本上我在 jinja 模板中有一些 html 看起来像......
<!--Select File Y-->
<tr>
    <td>File Y</td>
    <td>{{form.pathY }}</td>
    <td><input type=file name=browse ></td>
    <td><button onclick="window.location.href='{{ url_for( 'dataTablePage' , table='Y' ) }}';">Display Table Y</button></td>
</tr>
<tr>
    <td/>
    <td/>
    <td/>
    <td><a href="{{ url_for( 'dataTablePage' , table='Merged' ) }}">View Merged Data</a></td>
</tr>
在 DOM 中,这或多或少呈现了我期望的 location.href = '/DataTable/Y/'

但是,当我单击按钮时,我会在405 Method Not Allowed页面中显示此处。

另一方面,当我使用 url_for 从锚点重定向时,重定向按预期工作。在按钮的 onclick 重定向中使用 url_for 有什么关系?
不确定这是否重要,但这是我要连接的路线...
@app.route('/DataTable/<table>/')
def dataTablePage(table) :
    """
    Takes the user to the Table View corresponding to the given table parameter
    """
    table == "X" :
        dfTable = DataFrame( data = {"X1":[1,2,3] , "X2":[2,3,4]} ) 
    elif table == "Y" :
        dfTable = DataFrame( data = {"Y1":[1,2,3,4,5] , "Y2":[2,3,4,5,6]} ) 
    elif table == "Merged" :
        dfTable = DataFrame( data = {"M1":[1,2] , "M2":[2,3]} ) 
    else :
        redirect( url_for('error') )
    return render_template( 'dataTable.html' , filePath="x.csv" , headers=dfTable.columns.values.tolist() , table=dfTable.iterrows() )
这是你的HTML实际上,该问题默认"type"的button就是:
缺失值默认为提交按钮状态。
而且由于您没有指定按钮的类型,它只是尝试提交表单,这会导致 405 问题。
将您的按钮类型更改为"button",它应该可以按预期工作:
<button type="button" onclick="window.location.href='{{ url_for( 'dataTablePage' , table='Y' ) }}';">Display Table Y</button>
| 归档时间: | 
 | 
| 查看次数: | 26380 次 | 
| 最近记录: |