ExpressJS对象未定义模板错误

时间:2015-01-20 02:22:03

标签: node.js express routes ejs referenceerror

当我在我的视图中传递我的对象以供使用时,我不确定为什么我会收到ReferenceError: Object not defined错误。我通过一个视图运行两条路线。一个用于创建记录,另一个用于通过POST方法编辑记录。通过使用模板化的if / else语句,我让我的视图知道是否应该在我的表单字段中显示内容。当我在路径文件中调用blogpost : blogpost时出现错误的原因是什么?

错误:

ReferenceError: blogpost is not defined
   at /Users/user/Desktop/Projects/node/blog/app/routes.js:128:26
   at Layer.handle [as handle_request] (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/layer.js:76:5)
   at next (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/route.js:100:13)
   at isLoggedIn (/Users/user/Desktop/Projects/node/blog/app/routes.js:307:16)
   at Layer.handle [as handle_request] (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/layer.js:76:5)
   at next (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/route.js:100:13)
   at next (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/route.js:94:14)
   at Route.dispatch (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/route.js:81:3)
   at Layer.handle [as handle_request] (/Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/layer.js:76:5)
   at /Users/user/Desktop/Projects/node/blog/node_modules/express/lib/router/index.js:227:24

以下是我的路线遇到错误的部分:

router.route('/admin/posts/create')

    // START POST method
        .post(function(req, res) {

            console.log("New instance");

            var blogpost = new Blogpost(); // create a new instance of a Blogpost model

            blogpost.title = req.body.title; // set the blog title
            blogpost.featureImage = req.body.featureImage; // set the blog image
            blogpost.blogUrl = blogpost.title.toLowerCase().replace(/\s+/g,"-");
            blogpost.author = req.body.author; // set the author name
            blogpost.tagline = req.body.tagline; // set the tagline
            blogpost.content = req.body.content; // set the blog content
            blogpost.category = req.body.category; // set the category
            blogpost.tags = req.body.tags; // set the tags
                //Save Blog Post
                blogpost.save(function(err) {
                    if (err)
                        res.send(err);

                    res.redirect(303, '/'); //NEEDS TO BE CHANGED
                });

        }) // END POST method


        .get(isLoggedIn, function(req, res) {
            res.render('pages/blogpost-create', {
              blogpost : blogpost
            });
        });

我如何在我的视图中使用我的blogpost对象:

<html>
<head>
    <% include ../partials/head %>
    <script src="//cdn.ckeditor.com/4.4.5/standard/ckeditor.js"></script>
</head>

<body>

    <header>
        <% include ../partials/header %>
    </header>

    <div class="container">
        <div class="col-md-12">
            <h1>Blog Create</h1>

            <% if(blogpost && blogpost.blogUrl) { %> 

                <form action="/admin/posts/edit/<%= blogpost.blogUrl %>" method="POST">
                Header Image: <input type="file" id="files">
                <p id="status">Please select a file</p>
                <div id="preview"><img src="<%= blogpost.featureImage %>"></div>
                <input type="hidden" id="feature-image" name="featureImage" value="/images/event-placeholder.png" />
                Title: <input type="text" name="title" value="<%= blogpost.title %>"><br>
                Author: 
                    <select name="author">
                        <option value="Author">Connor Phillips</option>
                    </select><br>
                Category: 
                    <select name="category">
                        <option value="Analytics/SEO/SEM">Analytics/SEO/SEM</option>
                        <option value="Advice">Advice</option>
                        <option value="Programming">Programming</option>
                        <option value="Thoughts">Thoughts</option>
                    </select><br>
                Tagline: <input type="text" maxlength="160" name="tagline" value="<%= blogpost.tagline %>"><br>
                Content:<br>
                <textarea name="content" id="blog-editor" rows="10" cols="80">
                    <%= blogpost.content %>
                </textarea>
                <br>
                Tags: <input type="text" name="tags">
                <br>

                <% } else { %>


                <form action="/admin/posts/create" method="POST">
                Header Image: <input type="file" id="files"/>
                <p id="status">Please select a file</p>
                <div id="preview"><img src="/images/event-placeholder.png"></div>
                <input type="hidden" id="feature-image" name="featureImage" value="/images/event-placeholder.png" />
                Title: <input type="text" name="title"></input><br>
                Author: 
                    <select name="author">
                        <option value="Author">Test</option>
                    </select><br>
                Category: 
                    <select name="category">
                        <option value="Test">Test</option>
                        <option value="Test">Test</option>
                        <option value="Test">Test</option>
                        <option value="Test">Test</option>
                    </select><br>
                Tagline: <input type="text" maxlength="160" name="tagline"><br>
                Content:<br>
                <textarea name="content" id="blog-editor" rows="10" cols="80">

                </textarea>
                <br>
                Tags: <input type="text" name="tags">
                <br>

                <% } %>

                <input type="submit" value="Submit">
            </form>
        </div>
    </div>

    <script>
    // Replace the <textarea id="blog-editor"> with a CKEditor
                // instance, using default configuration.

                CKEDITOR.replace( 'blog-editor' );
                CKEDITOR.config.entities = false;   
                CKEDITOR.config.basicEntities = false;
                CKEDITOR.config.entities_greek= false;
                CKEDITOR.config.entities_latin= false;  
                CKEDITOR.config.htmlEncodeOutput = false;
                CKEDITOR.config.protectedSource.push = '/<\#[\s\S]*#\#>/g';



    </script>

    <script type="text/javascript" src="/js/s3upload.js" async></script>

    <script>
        console.log("S3 Function Launched");

        function s3_upload(){
            var status_elem = document.getElementById("status");
            var url_elem = document.getElementById("feature-image");
            var preview_elem = document.getElementById("preview");
            var s3upload = new S3Upload({
                file_dom_selector: 'files',
                s3_sign_put_url: '/sign_s3',
                onProgress: function(percent, message) {
                    status_elem.innerHTML = 'Upload progress: ' + percent + '% ' + message;
                },
                onFinishS3Put: function(public_url) {
                    status_elem.innerHTML = 'Upload completed. Uploaded to: '+ public_url;
                    url_elem.value = public_url;
                    console.log(public_url);
                    preview_elem.innerHTML = '<img src="'+public_url+'" style="width:300px;" />';
                },
                onError: function(status) {
                    status_elem.innerHTML = 'Upload error: ' + status;
                    console.log(status_elem.innerHTML);
                }
            });
        }
        /*
        * Listen for file selection:
        */
        (function() {

            var input_element = document.getElementById("files");
            input_element.onchange = s3_upload;
        })();
    </script>


    <footer>
        <% include ../partials/footer %>
    </footer>

</body>
</html>

1 个答案:

答案 0 :(得分:1)

Blogpost未定义,因为它未在您调用它的范围内定义。你定义了var blogpost = new Blogpost();在.post()定义中,但不在.get()中。我想您正在尝试将您在/ post路由中创建的博客帖子传递到/ get路由,但在/ redirect完成后该对象将不可用。