Ich versuche, so etwas wie Google erstellen vorschlagen Tool (über vorschlagen api http://suggestqueries.google.com/complete/search?output=toolbar&hl=ru&q=query)Flask Dynamische Datenaktualisierung ohne die Seite neu laden
I-Eingang Änderungen hören bin, und senden Daten gehen GET:
$("#search_form_input").keyup(function(){
var some_var = $(this).val();
$.ajax({
url: "",
type: "get", //send it through get method
data:{jsdata: some_var},
success: function(response) {
},
error: function(xhr) {
//Do Something to handle error
}
});
Danach ich bin Umgang mit diesen Daten und an Google API senden und bekam Antwort in Python:
@app.route('/', methods=['GET', 'POST'])
def start_page_data():
query_for_suggest = request.args.get('jsdata')
if query_for_suggest == None:
suggestions_list = ['',]
pass
else:
suggestions_list = []
r = requests.get('http://suggestqueries.google.com/complete/search?output=toolbar&hl=ru&q={}&gl=in'.format(query_for_suggest), 'lxml')
soup = BeautifulSoup(r.content)
suggestions = soup.find_all('suggestion')
for suggestion in suggestions:
suggestions_list.append(suggestion.attrs['data'])
print(suggestions_list)
return render_template('start_page.html', suggestions_list=suggestions_list)
in Jinja versuchen, es in HTML zu drucken dynamisch:
Aber Variable in Jinja wird nicht dynamisch aktualisiert und leere Liste gedruckt.
Wie Vorschläge aus Liste dynamisch in HTML drucken?
in JavaScript Ihre 'Erfolg:' Funktion ist leer Du machst also nichts mit Daten von Flask. – furas
Was muss ich reparieren? –
Ich denke, du weißt nicht, wie AJAX/JavaScript funktioniert. JavaScript sendet Daten an Flask, Flask sendet Daten zurück - besser als JSON - und JavaScript empfängt diese Daten und aktualisiert HTML im Browser. – furas