V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
woshichuanqilz
V2EX  ›  Flask

求助, flask 为什么没有接收到 request 事件?

  •  
  •   woshichuanqilz · Mar 14, 2018 · 3190 views
    This topic created in 2967 days ago, the information mentioned may be changed or developed.

    我做了一个简单的文件上传的网站, 文件上传之后会生成一个页面显示已经上传的文件,

    现在想做一个删除的功能, 在每个文件名后面加上一个 button, 点击可以删除这个文件。

    我的想法就是用 request 把文件的 id 传上去, id 包括对应的文件名, 然后后端的 flask 处理这个文件就行了。

    html 里面使用了 jinja, 现在的问题我在删除文件的链接里面 delfile print 一个提示, 但是这个提示在点击 button 之后并没有出现也就是说, 这个 delfile 没有走到, 请问是为什么?

    这个是文件名 + button 的 html 代码。

    <ul>
        {% for file_name, file_url in files.items() %}
           <li><a id="{{ file_name }}_url" href="{{ file_url }}">{{ file_name }}</a>&emsp;&emsp;
             <button id="{{ file_name }}_btn" class="delbtn">删除</button></li>
        {% endfor %}
    </ul>
    

    python:

    @app.route('/delfile', methods=['GET', 'POST'])
    def delfile():
        print('in delfile')
        return 'hello world'
    
    

    html :

    
    {% extends "layout.html" %}
    {% block body %}
    <div>
      {% if session.logged_in %}
        <h1><p>{{ session.cur_username }} 已经登录</p></h1>
      {% endif %}
      <br />
    </div>
    
    <div>
      <h2>已经使用的空间 <b>{{ used_space }}</b></h2>
    </div>
    <br />
    <div>
      <form method=post enctype=multipart/form-data>
           <input type=file name=file>
           <input type=submit value=上传>
      </form>
    </div>
    
    <div>
      <br /><br />
    </div>
    
    <ul>
        {% for file_name, file_url in files.items() %}
           <li><a id="{{ file_name }}_url" href="{{ file_url }}">{{ file_name }}</a>&emsp;&emsp;
             <button id="{{ file_name }}_btn" class="delbtn">删除</button></li>
        {% endfor %}
    </ul>
    
    {% endblock %}
    
    <script type=text/javascript>
      $(function() {
          $('.delbtn').click(function(){
            $.ajax({
              url: '/delfile',
              data:{
                filename: this.id
              },
              dataType: 'JSON',
              type: 'GET',
              success: function(data){
                  $("#result");
              }
              });
           });
      });
    </script>
    
    
    8 replies    2018-03-14 17:26:04 +08:00
    justinwu
        1
    justinwu  
       Mar 14, 2018
    好久没玩 flask 了,

    调试下啊,看看后端对不对,自己发个请求测试下,推荐工具 postman。
    看发送的请求对不对,把请求抓出来看看,浏览器自带 network 调试,也可以用 fiddler,wireshark 啥的。

    业余人士,回复仅供参考。。。
    boyxy120
        2
    boyxy120  
       Mar 14, 2018
    你先判断一下 request.method
    Linxing
        3
    Linxing  
       Mar 14, 2018
    你的 delfile 到底是给 post 用呢还是给 get 用呢
    yangzhezjgs
        4
    yangzhezjgs  
       Mar 14, 2018
    先定位问题在哪,先找到是服务端的问题,还是 ajax 的问题
    如果 print('in delfile')都没执行,先用 requests.get()一个请求,来确定路由函数有没有问题。
    如果服务端没问题,那就肯定是 ajax 没正确发送 http 请求,再来找问题再哪。。
    Beebird
        5
    Beebird  
       Mar 14, 2018
    浏览器开调试,在 ajax 的位置打断点看看。
    LeeSeoung
        6
    LeeSeoung  
       Mar 14, 2018
    首先 F12 看请求发出去没,再下一步定位。。
    TestSmirk
        7
    TestSmirk  
       Mar 14, 2018
    请问一下楼主,{% for file_name, file_url in files.items() %} 这个名词叫啥.
    woshichuanqilz
        8
    woshichuanqilz  
    OP
       Mar 14, 2018
    多谢各位解决了, 是我把 script 的位置写错了。。。

    @TestSmirk 一个 for 循环遍历 dict 里面的数据。jinja 语法
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5608 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 46ms · UTC 07:27 · PVG 15:27 · LAX 00:27 · JFK 03:27
    ♥ Do have faith in what you're doing.