如何在Jade中分配变量?

时间:2014-11-23 05:09:37

标签: javascript node.js express pug

我的应用程序所做的是,一旦用户登录,就会导出用户信息,以便路由器使用它来更新配置文件模板。但是,我希望我的应用程序要做的是,当用户仍然登录时,如果他/她进入主页,我不希望导航栏使用signin和注册链接进行渲染而不是希望是使用与配置文件页面相同的注销和用户名链接呈现导航栏。

所以我的错误是当用户请求主页时,路由器传递名为isSignedIn的变量以及模板名称。并且我希望变量(isSignedIn)的值存储在jade文件中的另一个变量中,这样如果用户是SignIn,则jade它将为主页呈现不同的导航栏。

玉无法执行此操作:    -var isSignedin =#{isSignedIn}

我的一些代码如下所示:

// app.js

app.post('/signup',
    passport.authenticate('signup_local_strategy',
        {successRedirect:'/profile',
         failureRedirect:'/signup_error'
        }));
passport.use('signup_local_strategy',new localStrategy(
    {passReqToCallback: true},
    function(req, username, password, done)
    {
        user_model.findOne({username:username},function(err, user){
            if(err)
            {
                return done(err);
            }
            if(user == null)
            {
                var new_user = new user_model({
                    username: username,
                    password: password,
                    university: req.body.university,
                    hometown: req.body.hometown
                });
                new_user.save(function(err){
                    if(err)
                    {
                        throw err;
                    }
                });
                user = new_user;    //Assigned the variable new_user to user to authematically serialize the new user.          
                return(done(null, user));
            }
            if(user.username == username)
                {
                    return(done(null, false));
                }       
        });     
    }
));
app.get('/profile', routes.userProfileResponseHandler);
app.get('/', routes.indexResponseHandler); 

//serialize user and export the the user information so that the router update the view
passport.serializeUser(function(user, done){
    done(null, user.id);
    exports.isSignedIn = true;
    exports._id = user.id;
    exports.username = user.username;
    exports.university = user.university;
    exports.hometown = user.hometown;
});

routes.js

exports.indexResponseHandler = function (req, res){
    res.render('index', {title: "College Clubs MN", isSignedIn: app.isSignedIn});
}

// index.jade

- var iSignedin = #{isSignedIn} // It could not assign #{isSignedIn} in the variable.
ul(class="nav navbar-nav navbar-right")
    if(isSignedIn=='true')
        li
            a(href="/signout") Signout
        li
            a(href="/profile") #{username}
    else
        li
            a(href="/signin") Sign in
        li
            a(href="/signup") Sign up

提前谢谢:)!

1 个答案:

答案 0 :(得分:1)

Object的{​​{1}}属性在模板中已被视为locals或局部变量。

// - var iSignedin = #{isSignedIn} // not necessary

ul(class="nav navbar-nav navbar-right")
    if isSignedIn
        // ...

res.render()index.jade之间没有额外的分隔层要求声明变量并将值输出到它。


错误是因为Jade的插值语法#{...}res.render()内无效。当需要在code内输出代码结果时,它不能与每个变量引用一起使用。

虽然多余,但该行在语法上有效:

- var isSignedIn = isSignedIn;