如何在jquery帖子

时间:2018-04-02 04:57:24

标签: javascript jquery redirect callback routing

我的主页收到数据后没有重定向到登录页面。 这是主页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

而发生的

2 个答案:

答案 0 :(得分:2)

.hrefwindow.location属性你可以获取/设置,而不是一个函数本身(从脚本编写者的角度来看)。试试这个:

window.location.href = data.url;

答案 1 :(得分:2)

您可以通过多种方式完成此操作。

首先让我告诉你代码中有什么问题,

你必须使用,

window.location.href = "https://www.example.com";

由于您所写的符号错误

window.location.href(data.url) // this is wrong

Window.location docs at MDN

现在采取其他方式,

您也可以在动作属性中指定标记中的post方法。

<form name="some_name" method="POST" action="/signup">
... Your Form ...
</form>