我的主页收到数据后没有重定向到登录页面。 这是主页js:
$(function(){
const submit = $('#submit');
const save = $('#save');
const email = $('#email');
const username = $('#username');
const password = $('#password');
const userlogin = $('#Username login');
const passlogin = $('#Password login');
save.click(function(e){
e.preventDefault();
$.post('/signup',{
email:email.val(),
username:username.val(),
password:password.val()
}, function(data){
console.log(1)
if(data.username){
localStorage.setItem("username",data.username)
}
window.location.href(data.url)
})
})
submit.click(function(e){
e.preventDefault();
$.post('/login',{
username:userlogin.val(),
password:passlogin.val()
}, function(data){
window.location.href(data.url)
})
})
})
这是后端存在的routes.js文件
app.post('/signup', function(req,res){
var a = [req.body.email,req.body.username,req.body.password];
Users.findOne({
where: { email: a[0],
username: a[1],
password: a[2],
}
}).then(users => {
if (users) {
res.send({
url:'/'
})
}
else{
Users.create({
email: a[0],
username: a[1],
password: a[2],
}).then(users => {
res.send({
url:'/profile',
username: a[1]
})
})
}
})
})
我需要在收到来自服务器的成功回调后重定向到/ profile。但是现在页面没有加载,但是用户名字段成功存储在localstorage中。 我相信它是由于window.location.href
而发生的答案 0 :(得分:2)
.href
有window.location
的属性你可以获取/设置,而不是一个函数本身(从脚本编写者的角度来看)。试试这个:
window.location.href = data.url;
答案 1 :(得分:2)
您可以通过多种方式完成此操作。
首先让我告诉你代码中有什么问题,
你必须使用,
window.location.href = "https://www.example.com";
由于您所写的符号错误
window.location.href(data.url) // this is wrong
现在采取其他方式,
您也可以在动作属性中指定标记中的post方法。
<form name="some_name" method="POST" action="/signup">
... Your Form ...
</form>