Take the 2-minute tour ×
Stack Overflow is a question and answer site for professional and enthusiast programmers. It's 100% free, no registration required.

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 ) }}";
share|improve this question
    
I'm kind of clueless in this area but this might help you. stackoverflow.com/questions/15537254/… –  Shashank Gupta Sep 14 '13 at 0:11
    
    
you'd like for list to be transformed into a query string and appended to the URL there in the last line? –  JAL Sep 14 '13 at 0:23
    
@JAL that's correct, none of the links Shashank posted seemed to show how to do this. Any ideas? –  Aloke Desai Sep 14 '13 at 1:32
1  
Oh yeah, you can do this in urllib of Python. stackoverflow.com/questions/5607551/python-urlencode-string –  JAL Sep 14 '13 at 2:42

1 Answer 1

up vote 2 down vote accepted

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 json("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.

share|improve this answer

Your Answer

 
discard

By posting your answer, you agree to the privacy policy and terms of service.

Not the answer you're looking for? Browse other questions tagged or ask your own question.