[英]JSON Post request is showing 200 success, but script is not executing
前端获取名称、年龄、城市,将其以 JSON 格式发送到我的后端 localhost:5100/getJson。
<form>
<div class="form-group">
<label for="text">Name:</label>
<input type="text" class="form-control" id="name" placeholder="Enter name" name="name">
</div>
<div class="form-group">
<label for="text">Age:</label>
<input type="text" class="form-control" id="age" placeholder="Age" name="age">
</div>
<div class="form-group">
<label for="text">City:</label>
<input type="text" class="form-control" id="city" placeholder="Enter city" name="city">
</div>
<button onclick = "MyFunction()" id = "submitButton" type="submit" class="btn btn-default">Submit</button>
<p id = "demo">
</p>
<script>
function MyFunction() {
var name = document.getElementById("name").value
var age = document.getElementById("age").value
var city = document.getElementById("city").value
jsonRequest = {"name":name, "age":age, "city":city}
fetch('http://localhost:5100/acceptJson', {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: jsonRequest
}).then(res => res.json())
}
</script>
我的后端是 python 中的 flask 服务器。
后端
app = Flask(__name__)
@app.route('/acceptJson',methods=['GET', 'POST'])
def acceptJson():
jsonData = request.json
name = jsonData['name']
age = jsonData['age']
city = jsonData['city']
postToDatabase(name,age,city)
return "Succesful"
if __name__ == '__main__':
app.run(host = "localhost", port = 5100)
现在,当我使用 Postman 之类的软件发出相同的 JSON 发布请求时,它可以工作,返回 200 并运行脚本。
但是当我通过代码执行时,它返回200并且不运行脚本,因此javascript中的POST显然有问题,但我不明白哪里错了。
问题似乎与您的前端有关。 在以下答案中,我假设您的表单是由“MyFunction”提交的。
在 HTML 这一行中:
<button onclick = "MyFunction()" id = "submitButton" type="submit" class="btn btn-default">Submit</button>
该按钮是一个提交类型的按钮。 当您单击该按钮时,浏览器将照常提交表单。 标签中没有“action”属性,请求被提交到您打开的网页,即没有请求被发送到后端。
可以在这个问题中找到解决方案: Form not submit with JS 。 但是,我会建议另一种方法来做到这一点。
您可以添加“event.preventDefault();” 在调用处理请求的 function 之前或将其添加到 function 的开头以阻止表单以传统方式自动提交。
<button onclick = "event.preventDefault();MyFunction()" id = "submitButton" type="submit" class="btn btn-default">Submit</button>
使用 preventDefault 的原因是它只停止浏览器默认行为,而其他解决方案(返回 false)停止传播 DOM 的事件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.