- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
好吧,这会有点长。我对 React 和 Redux 有点陌生。所以我有一个 React 和 Redux 前端,一个 Node 和 Express 后端以及用于数据库的 mySQL。
我正在构建门户网站的一部分,用户可以在其中创建就业机会。作业创建部分工作正常,但我在从数据库检索数据(GET 请求)时遇到问题。
结构如下:
有一个 postJobs.js 父组件,它有几个子组件:
所有这些子组件都是选项卡,通过单击选项卡来触发。
当通过 CreateJob 组件创建作业时,会在 DB(主键)中生成一个 jobID,然后将其发送到 Redux Store。
我使用相同的组件,即 CreateJob 来添加作业和更新作业以防止重复。
当用户成功创建作业后,他/她将导航到第二个选项卡(AddMoreDetails)。
我定义了一个用于从数据库获取创建的作业的操作,该操作将 jobID 作为参数(从 Redux 存储中检索 jobID 并将其传递给操作)。
但是我在 Node 后端收到“job_id 未定义”。我意识到它没有从 req.body 获取 jobId,但我无法找到如何将 jobID 从前端发送到后端的替代方案。
我已经在 Postman 中测试了 API,它工作正常。
这是我收到的错误以及相关的后端和前端代码:
错误
Unhandled rejection TypeError: Cannot read property 'job_id' of
undefined at jobsDao.getCurrentJob.then.result
后端
userRouter.js
router.get('/getCreatedJob', postJobController.getCreatedJob);
postJob.js
let getCreatedJob = (req, res) => {
let jobId = req.body.jobId;
let skills = [];
jobsDao.getCurrentJobSkills(jobId).then(result => {
result.forEach(skill => {
skills.push(skill.skill_id);
});
});
jobsDao.getCurrentJob(jobId).then(result => {
console.log(result);
res.send({
success: true,
message: 'Got recent Created Job ',
jobId: result[0].job_id,
jobTitle: result[0].job_title,
jobType: result[0].job_type_id,
jobSkills: skills
});
});
};
jobsDao.js
let getCurrentJobSkills = jobId => {
return Promise.using(getDBConnection(), connection => {
return connection.query(
`select skill_id from job_skill where job_id =
${connection.escape(jobId)}`
);
});
};
let getCurrentJob = jobId => {
return Promise.using(getDBConnection(), connection => {
return connection.query(
`select job_id,job_title,job_type_id from job where job_id
= ${connection.escape(jobId)}`
);
});
};
前端
apiConfig.js
export default {
getCreatedJob: {
url: '/api/secured/client/getCreatedJob',
method: 'GET',
data: {
jobId: ''
},
showResultMessage: false,
showErrorMessage: true
}
// Other API calls here
}
postJobAction.js
export const actionGetCreatedJob = data => {
const request = apiService('getCreatedJob', data);
return {
type: GET_CREATED_JOB,
payload: request
};
};
reducerPostJob.js
export default (state = INITIAL_STATE, action) => {
switch (action.type) {
case GET_CREATED_JOB:
console.log(action.payload.data);
return { ...state };
// Other cases here
default:
return state;
}
}
createJob.js
componentDidMount() {
const jobId = this.props.clientPostJob.jobId;
console.log(jobId); // The createdJob is is being logged here
correctly
if (jobId) {
this.props.actionGetCreatedJob({jobId})
.then(() => {
this.props.actionLoaderHide()
/* Add logic here for populating the form fields with the
data retrieved from db */
})
.catch(err => console.log(err));
}
}
const mapStateToProps = state => {
return {
clientPostJob: state.clientPostJob,
userInfo: state.userInfo.userData,
jobId: state.clientPostJob.jobId
};
};
const mapDispatchToProps = dispatch => {
return bindActionCreators({
actionLoaderHide,
actionLoaderShow,
actionGetCreatedJob,
},
dispatch
);
};
export default connect(
mapStateToProps,
mapDispatchToProps
)(CreateJob);
将 jobID 发送到后端的最佳方法是什么?
最佳答案
我个人会使用jobId
作为路径中的参数 ( /api/secured/client/getCreatedJob/<jobId>
)。您的代码表明您正在尝试将其发送到体内。
关于mysql - 将 JobID 从 React&Redux 前端传递到 NodeJS 后端时,req.body.jobId 显示未定义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57753841/
我正在开发一个 nodejs 项目快速应用程序。我的路线看起来像这样: router.get('/observe/:fileName', function(res, req){ var req
从 Facebook 初始成功登录并使用 passport-facebook 1.0.3 和 express 4.6.1 登录重定向回调后,req.session.passport 和 req.use
req.body有什么区别和 req.params.all()何时用于风帆 Controller ? 最佳答案 req.body是从请求正文中解析出来的任何内容,例如 POST 中的有效负载要求。 r
我想知道 req.query 和 req.body 有什么区别? 下面是一段代码,其中req.query用来。如果我使用 req.body 会发生什么而不是 req.query . 以下函数被调用作为
我以前问过类似的问题,但我注意到它在 Javascript 部分。对于现在可能出现的问题,我也有更具体的想法。 基本上,req.session.passport 在我的日志中是空的。每当我开始浏览我的
我不久前从某处盗取了这段代码,并想回来进一步了解它。 iv 在 pi 上运行它已经有一段时间了,没有任何问题,但是当我运行网络服务器时,我需要恢复操作系统的备份,自从这样做以来,我一直无法让它运行,如
Req.isAuthenticated()在登录后以及注册新用户后返回false。我需要做什么来修复它? 我有一个具有两个不同登录名的应用程序。一个用于“用户”,另一个用于“雇员”。 “用户”用户是我
我一直在拼凑来自几个不同教程的代码,以使用 MEAN 堆栈构建一个基本的待办事项应用程序,使用 node、express、angular 和 mongodb。一个教程介绍了为 GET、POST 和 D
我使用以下路由接收 url 中的参数: app.get('/:lang', function(req, res) { }); 我将推送 lang 的值并将其发送到一个函数,但我希望只能在用户不输入任何
根据条件,我需要销毁用户的当前 session ,并将他重定向到带有消息的登录页面。我使用 flash 来获得只显示一次的消息。除了这里,这在我的应用程序上无处不在,因为这里我在 req.sessio
Sample 'Advanced REST Client' Request 我正在使用 Postman 和高级 REST 客户端为以下代码创建基本 POST 请求 - 'use strict'; va
if (!req.session.cart) { req.session.cart = { styles: styles,
我正在尝试使用 NodeJs 脚本将文件上传到服务器。我正在尝试以下操作。 HTML Upload a zip file
通过 req.query[myParam] 和 req.params.myParam 获取 QUERY_STRING 参数有区别吗?如果是这样,我应该什么时候使用哪个? 最佳答案 鉴于这条路线 app
在 Shiny 的应用程序中,我使用 req 检查输入的有效性如果输入的要求为 TRUE(即不为空、不为 FALSE 等),则更新输出。 如果 req 我想运行一些代码是 FALSE,即使用 req(
我正在使用 Express 和 Body Parser。给定以下标题键: X-Master-Key 当我使用下面的代码片段时,它无法输出值 req.headers['X-Master-Key'] //
要么使用正文解析器 application/x-www-form-urlencoded body parser 或 json body parser 产生相同的结果。 这就是我调用 API 的方式 $
在nodejs中我们通常会做这样的事情: req.checkBody('name', 'Group name is required.').notEmpty(); 同样,我也做了这样的事情: req.
我正在使用 Multer 在 keystone 环境中解析多部分表单,并且无法访问路由 Controller 内的 req.body 和 req.file 数据 路线/index.js var key
我想了解这是为什么: req.session._id = doc._id; req.session.id = doc._id; console.log(typeof req.session._id);
我是一名优秀的程序员,十分优秀!