方式一:live-server

live-server是一款npm工具,可以在项目目录启动一个node服务,然后直接在浏览器中预览,并且自动全局监听实时更新

两种安装方式:

全局安装 npm i live-server -g
本地安装 npm i live-server --save-dev

直接使用live-server

首先在项目下npm初始化:npm init -y;

然后可以选择全局安装或者本地安装live-server,然后在package.json的scripts属性中添加如下代码:

"scripts": {
"server": "live-server ./ --port=8181 --host=localhost --proxy=/api:http://www.abc.com/api/"
}

其中包括了代理设置proxy。

然后npm run server执行下就会自动打开当前工程,默认指向index.html页面。

使用node

首先本地安装live-server,执行如下指令:

 npm i live-server --save-dev

然后在该项目下新建一个build.js,代码如下:

var liveServer = require("live-server");

 var params = {
port: 8181,
host: "localhost",
open: true,
file: "index.html",
wait: 1000,
logLevel: 2,
proxy: [['/api','http://www.abc.com/api/']]
};
liveServer.start(params);

最后在package.json的scripts下添加如下代码:

"scripts": {
"dev": "node build.js"
}

最后执行npm run dev就启动了本地静态页面,路径即是:http://localhost:8081/

详细参考地址:https://www.npmjs.com/package/live-server

方式二:http-server

全局安装http-server

npm i -g http-server

用法:

http-server [path] [options]

其中的path默认指向工程路径下的./public,如果不存在那么使用./。

options就是常见的配置,比如端口、代理地址等,常用配置:

  • -p or --port Port to use (defaults to 8080). It will also read from process.env.PORT. (设置端口)
  • -a Address to use (defaults to 0.0.0.0) (设置访问地址)
  • -P or --proxy Proxies all requests which can't be resolved locally to the given url. e.g.: -P http://someurl.com(设置代理地址)
  • -o [path] Open browser window after starting the server. Optionally provide a URL path to open. e.g.: -o /other/dir/ (默认打开浏览器)

cmd进入静态目录工程,可执行如下操作:

http-server ./ -o --port 8085 --proxy http://192.168.11.120:8888/

当然该条命令也可以缩写成如下:

hs ./ -o -p 8085 -P http://192.168.11.120:8888/

我们也可以初始化package.json,执行npm init -y,然后在package.json中的scripts字段中添加如下代码:

"scripts": {
"dev": "http-server ./ -o --port 8089 --proxy http://192.168.11.120:8888/"
}

最后执行npm run dev 也是一样的,使用http-server主要缺点是不能使浏览器自动刷新。

官网github地址:https://github.com/http-party/http-server

方式三:express搭建

使用express简单搭建

使用express搭建前端静态页面环境,在工程下新建build文件夹,建一个dev.js(开发环境启动文件)以及index.js(配置文件、如端口)。

我们只需要安装express以及http-proxy-middleware即可,如下:

npm i express http-proxy-middleware -D

index.js代码:

module.exports = {
port: 8081,
host: 'localhost',
proxyTable: [{
api: '/api',
target: 'http://192.168.1.112:8081/' }]
}

dev.js代码如下:

const express = require('express');
const { createProxyMiddleware } = require('http-proxy-middleware');
const {port = 8080,proxyTable = []} = require('./index.js'); const app = express();
app.use('/', express.static('./')); // 设置静态资源访问路径
proxyTable.forEach((item) => app.use(createProxyMiddleware(item.api, {
target: item.target, // 目标服务器 host
changeOrigin: true, // // 默认false,是否需要改变原始主机头为目标URL
ws: true // 是否代理websockets
}))) app.listen(port,() => {
console.log(`listen:${port}`);
})

在package.json中配置启动快捷键,如下:

"scripts": {
"dev": "node config/dev.js"
}

运行npm run dev 即可启动本地服务器,本地运行localhost:8081即可(默认运行工程下的静态文件index.html),如果需要方法其他静态页面添加相应路径即可。

其中http-proxy-middleware实际就是将http-proxy封装,使用起来更加方便简单,老版本http-proxy-middleware参考:http-proxy-middleware使用方法和实现原理(源码解读),其中新版本的http-proxy-middleware使用方式参考github

使用browser-sync实现热更新优化

代码如下:

const express = require('express');
const path = require('path');
const timeout = require('connect-timeout');
const { createProxyMiddleware } = require('http-proxy-middleware');
const { port = 8080, proxyTable = [], host = 'localhost' } = require('./index.js'); const app = express();
const pathname = path.resolve(__dirname, '../');
const bs = require('browser-sync').create('server'); app.use(timeout(60 * 1e3));
app.use((req, res, next) => {
if (!req.timedout) next();
});
app.use('/', express.static(`${pathname}`)); // 设置静态资源访问路径
proxyTable.forEach((item) => app.use(createProxyMiddleware(item.api, {
target: item.target, // 目标服务器 host
changeOrigin: true, // // 默认false,是否需要改变原始主机头为目标URL
ws: true // 是否代理websockets
}))) app.listen(port, () => {
bs.init({ // 开始一个Browsersync代理
proxy: `http://${host}:${port}`,
notify: true, // 通知
port: 8085,
// files: ['**'] // files 必须带上,不带上修改文件不会刷新;可以指定文件类型、文件等方式
files: [`${pathname}/resources/**/*.html`,`${pathname}/index.html`,`${pathname}/public/**/*.js`,`${pathname}/public/**/*.css`]
})
})

当然也可以用watch方法监听文件的变化,更改代码如下:

const express = require('express');
const path = require('path');
const timeout = require('connect-timeout');
const { createProxyMiddleware } = require('http-proxy-middleware');
const { port = 8080, hotUpdate = false, proxyTable = [], host = 'localhost' } = require('./index.js'); const app = express();
const pathname = path.resolve(__dirname, '../');
const bs = require('browser-sync').create('server'); app.use(timeout(60 * 1e3));
app.use((req, res, next) => {
if (!req.timedout) next();
});
app.use('/', express.static(`${pathname}`)); // 设置静态资源访问路径
proxyTable.forEach((item) => app.use(createProxyMiddleware(item.api, {
target: item.target, // 目标服务器 host
changeOrigin: true, // // 默认false,是否需要改变原始主机头为目标URL
ws: true // 是否代理websockets
}))) bs.watch(`${pathname}/resources/**/*.html`).on("change", bs.reload);
bs.watch(`${pathname}/index.html`).on("change", bs.reload);
bs.watch(`${pathname}/public/**/*.js`, function(event, file) {
if (event === 'change') {
bs.reload('*.js')
}
})
bs.watch(`${pathname}/public/**/*.css`, function(event, file) {
if (event === 'change') {
bs.reload('*.css')
}
}) app.listen(port, () => {
bs.init({ // 开始一个Browsersync代理
proxy: `http://${host}:${port}`,
notify: true, // 通知
port: 8085
})
})

注:Browsersync让浏览器实时、快速响应文件变化并自动刷新,Browsersync说明文档

方式四:使用node内置模块http启动服务

const http = require('http');
const fs = require('fs');
const path = require('path');
const httpProxy = require('http-proxy');
const childProcess = require('child_process'); // 可自动打开浏览器
const filepath = path.resolve(__dirname,'./');
const proxy = httpProxy.createProxyServer(); // 创建代理服务器
const {proxyTable = []} = require('./config/index.js'); http.createServer(function(req,res){
fs.readFile(filepath + req.url,function(err,data) {
proxyTable.forEach((item) => {
if(req.url.indexOf(item.api) !== -1) { // 匹配上接口代理
proxy.web(req,res,{target: item.target});
proxy.on('error',function(e) { // 代理失败处理
console.log(e);
})
} else {
if(err) {
res.writeHeader(404,{'content-type': 'text/html;charset="utf-8"'});
res.write('<h1>404错误</h1><p>你访问的页面/内容不存在</p>');
res.end();
} else {
res.write(data);
res.end();
}
}
}) })
}).listen(8080,() => {
console.log('服务启动了');
}); childProcess.exec('start http://localhost:8080/index.html');

然后在地址栏输入localhost:8080/index.html (其中我的index.html就放在根路径,根据具体路径填写)

换一种方式:

const http = require('http');
const fs = require('fs');
const path = require('path');
const httpProxy = require('http-proxy');
const childProcess = require('child_process'); // 可自动打开浏览器
const filepath = path.resolve(__dirname,'./');
const proxy = httpProxy.createProxyServer(); // 创建代理服务器
const {proxyTable = []} = require('./config/index.js');
const server = new http.Server(); server.on('request',function(req,res){
fs.readFile(filepath + req.url,function(err,data) {
proxyTable.forEach((item) => {
if(req.url.indexOf(item.api) !== -1) { // 匹配上接口代理
proxy.web(req,res,{target: item.target});
proxy.on('error',function(e) { // 代理失败处理
console.log(e);
})
} else {
if(err) {
res.writeHeader(404,{'content-type': 'text/html;charset="utf-8"'});
res.write('<h1>404错误</h1><p>你访问的页面/内容不存在</p>');
res.end();
} else {
res.write(data);
res.end();
}
}
}) })
}) server.listen(8080,() => {
console.log('服务启动了');
}); childProcess.exec('start http://localhost:8080/index.html');

方式五:Nginx配置

conf主要的配置代码:

http {
# nginx负载均衡配置
upstream dynamic_balance {
#ip_hash;
server 192.168.100.123: 8081;
}
# 省略其他
server {
listen 80;
server_name localhost;
#访问工程路径
root website;
index index.html index.htm; #转发把原http请求的Header中的Host字段也放到转发的请求
proxy_set_header Host $host;
#获取用户真实IP
proxy_set_header X - real - ip $remote_addr;
proxy_set_header X - Forwarded - For $proxy_add_x_forwarded_for; #接口转发
location /base/ {
proxy_pass http: //dynamic_balance;
} #启用history模式( 什么请求都只返回index.html)
location / {
try_files $uri $uri / /index.html;
}
}
}

参考

web前端常用的五种方式搭建本地静态html页面服务器的更多相关文章

  1. XFire构建web service客户端的五种方式

    这里并未涉及到JSR 181 Annotations 的相关应用,具体的三种方式如下 ① 通过WSDL地址来创建动态客户端 ② 通过服务端提供的接口来创建客户端 ③ 使用Ant通过WSDL文件来生成客 ...

  2. 五种方式让你在java中读取properties文件内容不再是难题

    一.背景 最近,在项目开发的过程中,遇到需要在properties文件中定义一些自定义的变量,以供java程序动态的读取,修改变量,不再需要修改代码的问题.就借此机会把Spring+SpringMVC ...

  3. Android数据存储五种方式总结

    本文介绍Android平台进行数据存储的五大方式,分别如下: 1 使用SharedPreferences存储数据     2 文件存储数据       3 SQLite数据库存储数据 4 使用Cont ...

  4. 实现web数据同步的四种方式

    http://www.admin10000.com/document/6067.html 实现web数据同步的四种方式 1.nfs实现web数据共享 2.rsync +inotify实现web数据同步 ...

  5. tomcat的虚拟目录映射常用的几种方式

      我们在项目部署的时候,可以采用多种方式,接下来我们将在实际中比较常用的几种方式总结如下. 1.可以直接将我们的项目丢到tomcat的webapps目录下,这样当tomcat重启的时候,我们就可以访 ...

  6. js页面跳转常用的几种方式(转)

    js页面跳转常用的几种方式 转载  2010-11-25   作者:    我要评论 js实现页面跳转的几种方式,需要的朋友可以参考下. 第一种: 复制代码代码如下: <script langu ...

  7. 【开发笔记】- Java读取properties文件的五种方式

    原文地址:https://www.cnblogs.com/hafiz/p/5876243.html 一.背景 最近,在项目开发的过程中,遇到需要在properties文件中定义一些自定义的变量,以供j ...

  8. linux下实现web数据同步的四种方式(性能比较)

    实现web数据同步的四种方式 ======================================= 1.nfs实现web数据共享2.rsync +inotify实现web数据同步3.rsyn ...

  9. Android_安卓为按钮控件绑定事件的五种方式

    一.写在最前面 本次,来介绍一下安卓中为控件--Button绑定事件的五种方式. 二.具体的实现 第一种:直接绑定在Button控件上: 步骤1.在Button控件上设置android:onClick ...

  10. javaScript中定义类或对象的五种方式

    第一种方式: 工厂方法 能创建并返回特定类型的对象的工厂函数(factory function). function createCar(sColor){ var oTempCar = new Obj ...

随机推荐

  1. 透视开源生态,OSGraph——GitHub全域数据图谱的智能洞察工具

    "透视开源生态,OSGraph--GitHub全域数据图谱的智能洞察工具 OSGraph (Open Source Graph) 是一个开源图谱关系洞察工具,基于GitHub开源数据全域图谱 ...

  2. layout文本相关

    Textview t=findViewById(R.id.t); ONE设置文本内容: 在XML中android:text直接写 在java中setText()中修改 注意点1继承appcompata ...

  3. LVM综合实验

    实验目标 创建并管理一个 LVM 卷组 (VG). 在卷组中创建.扩展和缩小逻辑卷 (LV). 创建和使用快照. 实验环境 Linux 服务器 三个可用的磁盘分区: /dev/sdb1, /dev/s ...

  4. Jmeter参数化4-数据库数据引入

    1. 下载jmeter依赖的mysql驱动包 jmeter要连接mysql数据库,首先得下载mysql驱动包.执行"select version()"查看数据库版本 mysql历史 ...

  5. [香橙派开发系列]使用wiringPi控制26个引脚

    目录 前言 一.香橙派使用的包 二.使用wiringPi包的命令 1.下载wiringOP 2.gpio readall信息分析 3.设置gpio的模式 4.设置gpio输出的电平 三.wiringP ...

  6. 什么是智慧城市(Smart City)?

    Smart City是一个常见的概念,但是这个东西,这个名词到底指代的是什么却一直搞不太清,于是就查了查资料,有了这篇blog. 参考: https://baijiahao.baidu.com/s?i ...

  7. 如何使用H100打游戏——这是史上最快GPU!我们测了四张H100!价值120万元!

    资料: 这是史上最快GPU!我们测了四张H100!价值120万元! 对显卡H100的测评视频.

  8. 国产计算框架mindspore在gpu环境下编译分支r1.3,使用suod权限成功编译并安装,成功运行——(修复部分bug,给出具体编译和安装过程)—— 第二部分:源码编译及编译后文件安装、运行

    前文: 国产计算框架mindspore在gpu环境下编译分支r1.3,使用suod权限成功编译并安装,成功运行--(修复部分bug,给出具体编译和安装过程)-- 第一部分:依赖环境的安装 我们已经进行 ...

  9. Mongolia地区民间风俗的一些理解

    声明:本文的内容为自己学习历史后的一些个人理解,其中内容的真实性并未考证. 总所周知,Mongolia地区有内外之分现在,但是以前均为我国领土,后来由于种种历史原因导致外Mongolia分离了出去,这 ...

  10. C# 委托和闭包

    前言 本文只是为了复习,巩固,和方便查阅,一些知识点的详细知识会通过相关链接和文献标记出来. 委托是什么 大部分的解释是 委托是一个对方法的引用,可以不用自己执行,而是转交给其他对象.就好比每天都有一 ...