【发布时间】:2019-07-09 06:51:23
【问题描述】:
我正在尝试学习如何使用 ajax 发送数据。单击提交按钮时,我希望 Ajax 将数据发送到与数据无关的特定路由以及与表单关联的路由。然而,Ajax 似乎没有发送任何东西。我在脚本中添加了三个 console.log() 语句,但没有一个被显示。
HTML 和 AJAX 代码
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<form class="" action="/submitData" method="post">
<input type="text" name="name">
<button id="submitForm" type="submit">Submit</button>
<script>
const el = document.getElementById(submitForm);
if (el) {
el.addEventListener('submit', addRecipe);
console.log('Step 1');
}
function addRecipe() {
var recipe = {
param1: 'value1',
param2: 'value2'
};
console.log('step 2')
let xml = new XMLHttpRequest();
xml.open("POST", "/add-recipe", true);
//Specify the type of data to be sent
xml.setRequestHeader("Content-type", "application/json; charset=utf-8");
xml.send(JSON.stringify(recipe));
console.log('step 3');
}
</script>
</body>
</html>
server.js 文件
const express = require('express');
const app = express();
const bodyParser = require('body-parser');
let urlencodedParser = bodyParser.urlencoded({extended: false});
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
app.listen(7000);
app.post('/add-recipe', function(req, res) {
var recipe = req.body.recipe;
console.log(recipe);
});
app.post('/submitData',urlencodedParser,function(req, res){
});
【问题讨论】:
标签: javascript html node.js ajax