如何使用Flask将数据从JS发送到Python?

Sne*_*ver 10 javascript python jquery flask

我正在使用Flask创建一个网站,我希望能够使用页面中的数据执行python代码.我知道我可以简单地使用表单,但它是一个单页,它在接收用户输入时不断更新,每次发生某些事情时重新加载页面都是一个巨大的麻烦.我知道我可以{{ function() }}在javascript里面做,但我如何{{ function(args) }}使用js变量在javascript里面做?到目前为止,我唯一能想到的是使用js更新像MongoDB这样的外部数据库,然后使用Python来读取它,但是这个过程会使网站变慢很多.

jQuery需要从Python函数中获取一个字典对象列表,然后可以在html中使用它.所以我需要能够做到这样的事情:

JS:

var dictlist = { getDictList(args) };
dictlist.each(function() {
    $("<.Class>").text($(this)['Value']).appendTo("#element");
});
Run Code Online (Sandbox Code Playgroud)

蟒蛇:

def getDictList(args):
    return dictlistMadeFromArgs
Run Code Online (Sandbox Code Playgroud)

Alp*_*ran 24

要使用Flask从Javascript获取数据到Python,您可以使用数据发出AJAX POST请求或AJAX GET请求.

Flask 有六种可用的HTTP方法,其中我们只需要GET和POST.两者都将jsdata作为参数,但以不同的方式得到它.这就是两个完全不同的语言在两个不同的环境中如Python和Javascript交换数据的方式.

首先,在Flask中实例化一个GET路由:

@app.route('/getmethod/<jsdata>')
def get_javascript_data(jsdata):
    return jsdata
Run Code Online (Sandbox Code Playgroud)

或POST一个:

@app.route('/postmethod', methods = ['POST'])
def get_post_javascript_data():
    jsdata = request.form['javascript_data']
    return jsdata
Run Code Online (Sandbox Code Playgroud)

/getmethod/<javascript_data>使用AJAX GET访问第一个如下:

$.get( "/getmethod/<javascript_data>" );
Run Code Online (Sandbox Code Playgroud)

第二个使用AJAX POST请求:

$.post( "/postmethod", {
    javascript_data: data 
});
Run Code Online (Sandbox Code Playgroud)

javascript_dataJSON字典或简单值在哪里.

如果您选择JSON,请确保将其转换为Python中的dict:

json.loads(jsdata)[0]
Run Code Online (Sandbox Code Playgroud)

例如.

得到:

@app.route('/getmethod/<jsdata>')
def get_javascript_data(jsdata):
    return json.loads(jsdata)[0]
Run Code Online (Sandbox Code Playgroud)

POST:

@app.route('/postmethod', methods = ['POST'])
def get_post_javascript_data():
    jsdata = request.form['javascript_data']
    return json.loads(jsdata)[0]
Run Code Online (Sandbox Code Playgroud)

如果你需要反过来,将Python数据推送到Javascript,创建一个简单的GET路由,不带参数,返回一个JSON编码的dict:

@app.route('/getpythondata')
def get_python_data():
    return json.dumps(pythondata)
Run Code Online (Sandbox Code Playgroud)

从JQuery中检索它并解码它:

$.get("/getpythondata", function(data) {
    console.log($.parseJSON(data))
})
Run Code Online (Sandbox Code Playgroud)

[0]json.loads(jsdata)[0]有没有因为当你解码Python中的JSON编码字典,你得到的单字典里面,存储在索引0的清单,让您的JSON解码后的数据如下:

[{'foo':'bar','baz':'jazz'}] #[0: {'foo':'bar','baz':'jazz'}]
Run Code Online (Sandbox Code Playgroud)

因为我们需要的只是内部的dict而不是列表,我们得到的项目存储在索引0这是dict.

还有import json.

  • @SneakyBeaver 抱歉,有一个错字,已修复。 (2认同)
  • 因此,如果我选择 post 路线,我可以执行类似 var dictlist = $.post( "/postmethod", { javascript_data: data } ); 的操作 让 python 返回一个 dict,并能够使用 dictlist 作为 js 中的普通 dict 对象数组?另外(jsdata)后面的[0]有什么作用? (2认同)
  • 那是另一种方式.如果*你需要*是将Python数据推送到Javascript你只需要一个没有参数的GET路由返回一个用JSON`json.dumps(dictlist)`编码的字典,并在JQuery中检索它,如`$ .get("/ getmethod",function(data){console.log(data)})`.如果您经常这样做,我建议使用[Long Polling](http://en.wikipedia.org/wiki/Push_technology)或[Server Sent Events](http://www.w3schools.com) /html/html5_serversentevents.asp). (2认同)
  • 明白了。我需要将一个字符串从 js 发送到 python,然后将另一个函数派生的字典从 python 发送到 js。我是否需要在 JS 内部做任何特殊的事情来转换 JSON,或者 JSON 只是 JS 内容的编码方式?抱歉,我对这一切还很陌生,直到大约一周前,我使用的唯一语言是 Python,而且我所做的一切都非常简单。 (2认同)
  • 是的,我忘了那一步.你必须用JSON解码[$ .parseJSON(数据)](https://api.jquery.com/jquery.parsejson/)把它当作一个Javascript对象,否则将无法正常工作. (2认同)
  • 这有很大帮助。谢谢! (2认同)

Ays*_*yse 5

.html

... id="clickMe" onclick="doFunction();">
Run Code Online (Sandbox Code Playgroud)

.js

    function doFunction()
    {
        const name = document.getElementById("name_").innerHTML

        $.ajax({
            url: '{{ url_for('view.path') }}',
            type: 'POST',
            data: {
                name: name
            },
            success: function (response) {
            },
            error: function (response) {
            }
        });

    };
Run Code Online (Sandbox Code Playgroud)

.py

@app.route("path", methods=['GET', 'POST'])
def view():
    name = request.form.get('name')
    ...
Run Code Online (Sandbox Code Playgroud)