I have a function in flask called array that takes in a list and prints out the items in the list:
def array(list):
string = ""
for x in list:
string+= x
return string
On the client side, I want to pass in a javascript array named str into this array. How would I do that? Here's what I have right now, but Flask isn't reading the added variable. Any ideas?
for (var i = 0; i < response.data.length; i++) {
console.log(i);
// str = str + "<br/><b>Pic</b> : <img src='"+ response.data[i].picture +"'/>";
str[i] = response.data[i].picture;
}
window.location = "{{ url_for('array', str=list ) }}";
Flask has a built in object called request. In request there is a multidict called args.
You can use request.args.get('key')
to retrieve the value of a query string.
from flask import request
@app.route('/example')
def example():
# here we want to get the value of the key (i.e. ?key=value)
value = request.args.get('key')
Of course this requires a get request (if you use a post then use request.form
). On the javascript side you can make a get request using pure javascript or jquery.
I'm going to use jquery in my example.
$.get(
url="example",
data={key:value},
success=function(data) {
alert('page content: ' + data);
}
);
This is how you pass data from the client into flask. The function portion of the jquery code is how you pass data from flask to jquery. Let's say for example you have a view called /example and from the jquery side you pass in a key value pair of "list_name":"example_name"
from flask import jsonify
def array(list):
string = ""
for x in list:
string+= x
return string
@app.route("/example")
def example():
list_name = request.args.get("list_name")
list = get_list(list_name) #I don't know where you're getting your data from, humor me.
array(list)
return jsonify("list"=list)
and in the success function in jquery you'd say
success=function(data) {
parsed_data = JSON.parse(data)
alert('page content: ' + parsed_data);
}
Note that flask does not allow for top level lists in json response for security reasons.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With