- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我制作了一个 html 网页,其中附加了 .css、图像和 javescript 文件。但是,当我使用以下命令运行 Node 服务器时:
app.get('/', 函数(req, res){
res.sendFile(__dirname + '/index.html');
});
它确实在本地主机上打开我的网页,但出现错误,指出找不到附加文件,例如样式表图像和脚本。如果我只是运行我的index.html 页面,它就可以正常工作。错误在哪里?
我所做的是分别运行我的index.html和server.js,它确实有效。但每当我尝试通过 Node 服务器发布index.html页面时,它都不起作用。
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var fs = require('fs');
server.listen(8080, function() {
console.log("wagwan")
});
app.get('/', function(req, res) {
res.sendFile(__dirname + '/index.html');
});
io.on('connection', function(socket) {
socket.on('turnon', function(data) {
console.log(data.turnon);
//serialPort.write("on");
});
socket.on('turnoff', function(data) {
console.log(data.turnoff);
// serialPort.write("off");
});
});
.background {
background-repeat: no-repeat;
/* custom background-position */
background-position: 50% 50%;
/* ie8- graceful degradation */
background-position: 50% 50%\9 !important;
}
/* fullscreen setup */
html,
body {
/* give this to all tags from html to .fullscreen */
height: 100%;
}
.fullscreen,
.content-a {
width: 100%;
min-height: 100%;
}
.not-fullscreen,
.not-fullscreen .content-a,
.fullscreen.not-overflow,
.fullscreen.not-overflow .content-a {
height: 100%;
overflow: hidden;
}
/* content centering styles */
.content-a {
display: table;
}
.content-b {
display: table-cell;
position: relative;
vertical-align: middle;
text-align: center;
color: #2d2bde;
font-size: 35px;
font-family: 'Arial Rounded MT';
}
/* visual styles */
body {
margin: 0;
font-family: sans-serif;
font-size: 28px;
line-height: 100px;
color: #ffffff;
text-align: center;
}
section {
background: #9ed100;
}
.not-fullscreen {
height: 50%;
}
button,
.button,
input[type="reset"],
input[type="submit"],
input[type="button"] {
background: none;
background-color: #199cd8;
background-clip: border-box;
border: 1px solid transparent;
border-radius: 4px;
color: #fff;
outline: none;
font-size: 12px;
font-weight: 400;
letter-spacing: 1px;
padding: 0 20px;
text-transform: uppercase;
line-height: 40px;
display: inline-block;
zoom: 1;
*display: inline;
box-shadow: none;
text-shadow: none;
}
.top {
background-color: #199cd8;
height: 68px;
padding-top: 20px;
line-height: 50px;
overflow: hidden;
}
.banner {
padding: 1px 16px;
}
.w3-wide {
font-family: "Segoe UI", Arial, sans-serif !important;
letter-spacing: 4px;
}
.w3-right {
float: right !important;
}
.sitelogo {
margin: 0;
margin-right: 20px;
width: 60px;
height: 60px;
border: none;
}
<!DOCTYPE HTML>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<script src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
<meta charset="utf-8">
<meta name="description" content="Web to serial Arduino">
<title>Web to serial Arduino</title>
<script src="socket.io/node_modules/socket.io-client/socket.io.js"></script>
<script>
//var socket = io.connect('http://localhost:8080');
var socket = io('http://localhost:8080', {
'transports': ['websocket', 'polling']
});
</script>
</head>
<body>
<div class="banner top">
<a href="index.html">
<img src="Drawing.png" alt="logo" class="sitelogo">
</a>
<div class="w3-right toptext w3-wide">An Arduino project for robotic Arm</div>
</div>
<div class="fullscreen background" style="background-image:url('http://cdns.nocamels.com/wp-content/uploads/2013/10/bigstock-Business-technologies-today-43292197.jpg');" data-img-width="1600" data-img-height="1064">
<div class="content-a">
<div class="content-b">
<br>WELCOME TO Arduino "A simple function to test node.js"
<br>
<div class="button" onclick="socket.emit('turnon', { turnon:'on'});">
Turn On
</div> <span style="color: #ffffff;"><a class="button primary-button" onclick="socket.emit('turnoff', {turnoff:'off'});">Turn off</a> </span>
<br>
<div class="button" onclick="console.log('connected');">
connect
</div> <span style="color: #ffffff;"><a class="button primary-button" onclick="console.log('reset');">Reset</a> </span>
</div>
</div>
</div>
</body>
</html>
最佳答案
您想要做的是提供“静态”文件。 Javascript、CSS 等称为静态文件。
您的路线:
app.get('/', function(req, res) {
res.sendFile(__dirname + '/index.html');
});
正在发送您的index.html文件,但您的node.js服务器(express应用程序)没有为您的静态文件提供服务。
像这样:
app.use(express.static('public'));
或
app.use(express.static(__dirname + '/public'));
应该能解决你的问题。
“服务文件,例如图像、CSS、JavaScript 和其他静态文件是在 Express 中的内置中间件 -express.static 的帮助下完成的。
将要标记为静态 Assets 位置的目录名称传递给express.static中间件以直接开始提供文件服务。例如,如果您将图像、CSS 和 JavaScript 文件保存在名为 public 的目录中,则可以执行以下操作:"
http://expressjs.com/starter/static-files.html
此外,您似乎正在使用套接字。我建议您在进入套接字之前更好地学习express和node。简化您的代码,将其范围缩小到具体细节,并了解其工作原理。 Socket 很酷,但对于很多项目来说是不必要的。
关于javascript - 无法使用node js服务器访问html内容,,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33201595/
我用运行 Node node --debug app OR node --debug-brk app 它有反应 debugger listening on port 5858 Express serv
这个问题在这里已经有了答案: What is the difference between (int *i) and (int* i) in context of both C and C++? [
我有一个应用程序,它通过消息队列将数据库写入命令分派(dispatch)给工作人员(数量非常大),因此无法保证它们的接收顺序。 我有两个 Node ,例如“Account”和“Media”。在此假设的
有没有办法在调用 ts-node 时将选项传递给 Node ?我正在尝试在 Node 中使用一个实验性功能,如果它能与 ts-node 一起使用,那就太好了。 这就是我目前正在做的事情: ts-nod
我有一个容器化的Node应用程序,它在DigitalOcean服务器上运行。当我更新服务器上的应用程序时,该应用程序必须关闭一小段时间。为了能够更新应用程序并避免停机,我目前正在阅读零停机时间部署/蓝
我正在编写一个 Node.js 应用程序。我正在使用 request 和 Cheerio 加载一组 URL 并获取该网站的大量信息,现在假设我想要获取的只是标题: var urls = {"url_1
如果不弹出以下错误,我无法安装任何 Node.js 模块。错误代码引用package.json文件。如果知道为什么会发生这种情况,我们将不胜感激。 最佳答案 这些不是错误,它们只是警告。一切都应该如此
如果我运行(从我的项目目录中): supervisor javascripts/index.js 我得到:/usr/bin/env: Node :没有这样的文件或目录 如果我运行: node java
我已遵循使用 Node-Inspector 的所有步骤 但是当我打开应用程序时,我在控制台上看不到任何脚本或日志。 我的应用程序在端口 4000 上运行。我认为唯一可能发生冲突的是端口 8080 上的
我在android中使用rxjava2,有时会遇到这样的问题: Observable.fromArray( // maybe a list about photo url in SD
我目前正在使用 Node 光纤来编写同步服务器端代码。我主要通过 try-catch block 进行错误处理,但外部库或其他小部分异步代码中总是有可能发生错误。我正在考虑使用新的域功能来尝试将这些错
看起来node-debug是node-inspector周围的一个shell?分别什么时候应该使用? 最佳答案 如果您安装node-debug,您只能访问node-debug命令。 如果您安装node
我目前正在代理后面工作,该代理不允许我执行此命令的 HTTP GET 请求阶段: Node node-sass/scripts/build.js 请求阶段: gyp http GET https://
听说node js可以用在服务端。我以前用过jsp。 jsp页面内部的java代码对客户端是不可见的。如果 Node js 只是 javascript,那么它如何对客户端不可见? 最佳答案 首先,No
我正在为 Node native 插件从 node-waf 构建迁移到 node-gyp 构建系统。 node-gyp 说它支持多个目标版本,但我在使用 node-gyp 时找不到如何指定目标 Nod
给定一个 $node ,我正在尝试在以下两种输出该 $node 的方式之间做出决定。 要么 $output = theme('node', $node); 或 node_build_content($
如果package.json中的窗口A打开一个新窗口B,node-main如何访问它?这是我的代码: package.json { "main": "index.html",
我试图在我的 xml 中的特定节点 ( ) 之前插入一个注释节点。这是它的方法: function test(xmlResponse) { var parser = new DOMParse
我正在尝试做npm install wrtc使用 Node 版本 16.14.0 但这还没有完成。它在给npm error code 1所以我试图将 Node 版本更改为以前的 lts 14.19.0
当我在 Visual Studio 中运行 Node.js 应用程序时,我收到以下消息:DeprecationWarning: 'node --debug' 和 'node --debug-brk'
我是一名优秀的程序员,十分优秀!