javascript - Node.js/jade语法错误: unexpected token ;

标签 javascript node.js pug

我正在尝试学习 node.js。我正在研究 OReilly 书中的一个示例“使用 mongodb 和主干构建 Node 应用程序”。我遇到了一个错误,但我一直无法解决。

我查找了一段时间的错误(在我自己的代码版本中)。大多数类似的案例都与 jade 解析注释有关(我在这里没有使用)。看起来另一种可能性是模块版本与此代码或彼此不兼容,但我不准备深入研究。我完全从示例中复制了代码,而不是使用我自己的版本,我得到了相同的结果。

痕迹指向 Jade 模板中的一条线,但我不确定问题到底出在哪里。

这是来自示例 .js 文件的代码:

var http = require('http');
var express = require('express');
var app = express();
var server = http.createServer(app);
var io = require('socket.io').listen(server);

var catchPhrases = ['Why I oughta...', 'Nyuk Nyuk Nyuk', 'Poifect!', 'Spread out!', 'Say a few syllables!', 'Soitenly!'];

app.set('view engine', 'jade');
app.set('view options', { layout: true});
app.set('views', __dirname + '/views');

app.get('/stooges/chat', function(req, res, next) {
res.render('chat');
});

io.sockets.on('connection', function(socket) {
var sendChat = function(title, text) {
socket.emit('chat', {
title: title,
contents: text
});
};

setInterval(function() {
var randomIndex = Math.floor(Math.random() * catchPhrases.length);
sendChat('Stooge', catchPhrases[randomIndex]);
}, 5000);

sendChat('Welcome to Stooge Chat', 'The Stooges are on the line');

socket.on('chat', function(data) {
sendChat('You', data.text);
});
});

app.get('/?', function(req, res) {
res.render('index');
});

var port = 8080;
server.listen(port);
console.log('Listening on port ' + port);

这是相应的 Jade 模板:

extends layout

block scripts
script(type='text/javascript', src='/socket.io/socket.io.js')
script(type='text/javascript')
var socket = io.connect('http://localhost:8080');
socket.on('chat', function(data) {
document.getElementById('chat').innerHTML = '<p><b>' + data.title + '</b>: ' + data.contents + '</p>';
});
var submitChat = function(form) {
socket.emit('chat', {text: form.chat.value});
return false;
};

block content
div#chat

form(onsubmit='return submitChat(this);')
input#chat(name='chat', type='text')
input(type='submit', value='Send Chat')

这是输出:

   info  - socket.io started
Listening on port 8080
SyntaxError: /home/rob/Documents/Node/views/chat.jade:9
    7| socket.on('chat', function(data) {
    8| document.getElementById('chat').innerHTML = '<p><b>' + data.title + '</b>: ' + data.contents + '</p>';
  > 9| });
    10| var submitChat = function(form) {
    11| socket.emit('chat', {text: form.chat.value});
    12| return false;

Unexpected token ;
    at Function (<anonymous>)
    at assertExpression (/home/rob/Documents/Node/node_modules/jade/lib/lexer.js:31:3)
    at Object.Lexer.attrs (/home/rob/Documents/Node/node_modules/jade/lib/lexer.js:648:20)
    at Object.Lexer.next (/home/rob/Documents/Node/node_modules/jade/lib/lexer.js:868:15)
    at Object.Lexer.lookahead (/home/rob/Documents/Node/node_modules/jade/lib/lexer.js:114:46)
    at Parser.lookahead (/home/rob/Documents/Node/node_modules/jade/lib/parser.js:100:23)
    at Parser.peek (/home/rob/Documents/Node/node_modules/jade/lib/parser.js:77:17)
    at Parser.tag (/home/rob/Documents/Node/node_modules/jade/lib/parser.js:733:22)
    at Parser.parseTag (/home/rob/Documents/Node/node_modules/jade/lib/parser.js:719:17)
    at Parser.parseExpr (/home/rob/Documents/Node/node_modules/jade/lib/parser.js:188:21)

最佳答案

在 Jade 模板中编写内联 JavaScript 时,您需要在脚本标签后添加一个点。你也应该缩进你的代码。 IE。它应该是这样的:

script(type='text/javascript', src='/socket.io/socket.io.js')
script(type='text/javascript').
    var socket = io.connect('http://localhost:8080');
    socket.on('chat', function(data) {
        document.getElementById('chat').innerHTML = '<p><b>' + data.title + '</b>: ' + data.contents + '</p>';
    });
    var submitChat = function(form) {
        socket.emit('chat', {text: form.chat.value});
        return false;
    };

关于javascript - Node.js/jade语法错误: unexpected token ;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22524986/

相关文章:

javascript - jade/pug 中的导入语句

node.js - Jade 中的布局继承

javascript - 将 index.html 移至公用文件夹时设置新 React 项目时出错

JavaScript - for循环迭代不适用于indexOf函数

node.js - Jade 变量渲染内标签规范

javascript - 你如何从 server/app.js 服务 client/index.html?

image - 在这个node.js图像模块中,我应该使用哪个? (读取流还是从路径?)

javascript - 使用 Jquery 防止在 html() 期间创建 html 标签

javascript - Hide() 下拉内容使其消失

javascript - res.render() 后手写笔未应用于我的 Jade 文件