程序员社区

Flask使用ajax进行前后端交互

ajax前后端交互的使用已经非常普及了, 这种数据交互方式比表单提交数据带给用户的使用体验更好一些。同时,利用ajax交互时数据传输一般使用json,我们可以很方便的管理我们所需要的数据。只需要定义好数据格式,可以前后端分离开发。

我们这里改一下之前图片上传的代码,使用ajax方式上传图片。

html表单:

<div style="width:100px;float:left;margin-left:35px;">
        <form method="post" enctype="multipart/form-data" id="test_form" style="margin-top:45px;">
             <a href="javascript:;" class="file button red">选择照片
             <input type="file" name="photo" id="photo">
              </a>
             <a type="button" class="file button red" id="tj" οnclick="ajaxForm()">上传照片</a>
             <a class="file button red" data-reveal-id="myModal">手动裁剪</a>
        </form>
 </div>

Js代码:

function ajaxForm(){
        var form= new FormData(document.getElementById("test_form"));
        $.ajax({
            url:"{{ url_for('api_upload') }}",
            type:"post",
            data:form,
            dataType: 'json',
            processData:false,
            contentType:false,
            success:function(data){
                    $(img_url_new).attr("src",data.img_url_new);
                    $(imgPic).attr("src",data.img_url_new);
            },
            error:function(e){
                    alert("error");
            }
        })
}
注意,需要引入jquery。
data为获取的表单数据,以json格式通过post方法传入后台,成功后从后台获取数据data,失败则弹出error。
后台接收代码:
@app.route('/up_photo', methods=['POST'], strict_slashes=False)
def api_upload():
    file_dir = os.path.join(basedir, app.config['UPLOAD_FOLDER'])
    if not os.path.exists(file_dir):
        os.makedirs(file_dir)
    f = request.files['photo']
    if f and allowed_file(f.filename):
        fname = secure_filename(f.filename)
        ext = fname.rsplit('.', 1)[1]
        new_filename = Pic_str().create_uuid() + '.' + ext
        print new_filename
        f.save(os.path.join(file_dir, new_filename))
        img_url = ip+'show/'+new_filename
        img_url_new = ip+'show/'+new_filename  #处理后的图片,假数据

        return jsonify({"success": 200, "msg": "上传成功", "img_url": img_url, "img_url_new": img_url_new})
    else:
        return jsonify({"error": 1001, "msg": "上传失败"})
通过上传图片的小例子我们大概了解了Flask使用ajax交互的基本方式,下面通过一个更加符合ajax使用场景的例子来加深理解它。

如,有这样一个场景,我们希望鼠标点击图片时将点击坐标传入后台,这时就必须使用ajax来实现了。

html页面代码:
<div id="myModal" class="reveal-modal">
            <h1>点击选择裁剪坐标</h1>
            <div class="uploader blue">
                <img id="imgPic" src="{{ url_for('static', filename='img/1.jpg') }}" οnclick="Show(this)" style="width:300px;height:270px;"/>
                X:<input id="xxx" type="text" style="width:30px;"/>  Y:<input id="yyy" type="text" style="width:30px;"/>
            </div>
            <a class="close-reveal-modal">×</a>
 </div>

js代码:

<!--获取图片坐标-->
    function mousePosition(ev){
     if(ev.pageX || ev.pageY){
      return {x:ev.pageX, y:ev.pageY};
      }
      return {
       x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,
       y:ev.clientY + document.body.scrollTop  - document.body.clientTop
       };
    }
    function mouseMove(ev){
        ev = ev || window.event;
        var mousePos = mousePosition(ev);
        document.getElementById('xxx').value = mousePos.x;
        document.getElementById('yyy').value = mousePos.y;
    }
    document.onmousemove = mouseMove;
      function Show(el){
          var x = parseInt(document.getElementById('xxx').value)-el.offsetLeft;
          var y = parseInt(document.getElementById('yyy').value)-el.offsetTop;
          var data= {
                data: JSON.stringify({
                    'x': x,
                    'y': y
                }),
            }
          $.ajax({
            url:"{{ url_for('img_operate') }}",
            type:"post",
            data:data,
            dataType: 'json',
            success:function(data){
                 //成功后的一些操作

            },
            error:function(e){
                 alert("error");
            }
        })
   }
注意,我们这里通过json格式将数据传入后台:
var data= {
                data: JSON.stringify({
                    'x': x,
                    'y': y
                }),
            }
那么后台如何接收x、y轴坐标呢?
data = json.loads(request.form.get('data'))
    x = data['x']
    y = data['y']

以上为接收ajax前台传入数据的方法,后台路由方法完整代码:
# 坐标操作图片处理的按钮路由
@app.route('/img_operate', methods=['POST'])
def img_operate():
    data = json.loads(request.form.get('data'))
    x = data['x']
    y = data['y']
    print(x)
    print(y)
    img = 'http://localhost:5000/static/img/1.jpg'
    return jsonify({"success": 200, "img": img, "x": x, "y": y})
以上这些介绍了ajax前后台交互的基本方法。

赞(0) 打赏
未经允许不得转载:IDEA激活码 » Flask使用ajax进行前后端交互

一个分享Java & Python知识的社区