原生JS實現(xiàn)Ajax跨域請求flask響應內容
更新時間:2017年10月24日 09:22:25 作者:嵐漾憶雨
這篇文章主要為大家詳細介紹了JS實現(xiàn)Ajax跨域請求flask響應內容,具有一定的參考價值,感興趣的小伙伴們可以參考一下
Ajax方法好,網(wǎng)站感覺跟高大上,但由于Js的局限,跨域Ajax無法實現(xiàn),這里,講一下解決辦法,前提是需要能夠自己可以控制flask端的響應。
主要技術:
修改服務器相應的相應頭,使其可以相應任意域名。and設置響應頭,使其能夠相應POST方法。
實現(xiàn)代碼:
這里先放flask代碼:
from flask import make_response
@app.route('/test',methods=['get','post'])
def Test():
if request.method=='GET':
rst = make_response('aaa')
rst.headers['Access-Control-Allow-Origin'] = '*' #任意域名
return rst
else:
rst = make_response('bbb')
rst.headers['Access-Control-Allow-Origin'] = '*'
rst.headers['Access-Control-Allow-Methods'] = 'POST' #響應POST
return rst
html測試代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<span id="ss">test get</span>
<button onclick="getAjax()">click</button>
<p id="time">test post</p>
<input type="submit" value="click" onclick="getPostAjax()">
<script>
function getPostAjax() {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange=function () {
if(xmlhttp.readyState=4 && xmlhttp.status ==200 ) {
document.getElementById("time").innerText = xmlhttp.responseText;
}
}
xmlhttp.open("POST","http://localhost:5000/test",true);
xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
#這句話可以發(fā)送post數(shù)據(jù),沒有此句post的內容無法傳遞
xmlhttp.send();
}
function getAjax() {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange=function () {
if(xmlhttp.readyState==4 && xmlhttp.status == 200){
document.getElementById("ss").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","http://localhost:5000/test",true);
xmlhttp.send();
}
</script>
</body>
</html>
無法控制響應頭
對于這種情況,get請求可以使用jquery完成,post,無能為力。目前前后端均我一人編寫,暫不考慮慮此情況。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JavaScript設計模式之策略模式實現(xiàn)原理詳解
這篇文章主要介紹了JavaScript設計模式之策略模式實現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-05-05
小程序開發(fā)中如何使用async-await并封裝公共異步請求的方法
在平常的項目開發(fā)中肯定會遇到同步異步執(zhí)行的問題,這篇文章主要介紹了小程序開發(fā)中如何使用async-await并封裝公共異步請求的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01
javascript間隔定時器(延時定時器)學習 間隔調用和延時調用
這篇文章主要介紹了javascript間隔調用和延時調用示例,介紹setInterval方法和clearInterval方法的使用方法,大家參考使用吧2014-01-01

