nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > Nginx搭建前端本地预览环境

Nginx搭建前端本地预览环境的完整步骤教学

作者:llq_350

这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

很多前端同学平时只接触 npm run dev 的开发模式。但在一些场景下,我们需要用 Nginx 来本地模拟部署环境,比如:

下面我们来一步步看怎么在本地用 Nginx 来托管前端项目。

项目目录结构

.
├── logs              # 存放 Nginx 访问日志和错误日志
│   ├── access.log
│   └── error.log
├── nginx.conf        # Nginx 配置文件
├── nginx.sh          # Nginx 启动/停止/重载脚本
├── package.json      # npm 脚本配置
└── utils.sh          # (可选)工具脚本

这样整理后,前端项目和本地 Nginx 部署逻辑绑定在一起,不需要频繁写长命令。

核心配置文件:nginx.conf

worker_processes 1;       # 启动的 worker 数量

events {
    worker_connections 1024;  # 每个 worker 最大连接数
}

http {
    include /opt/homebrew/etc/nginx/mime.types;   # 识别常见文件类型
    default_type application/octet-stream;

    sendfile on;              # 高效传输文件
    keepalive_timeout 65;     # 长连接超时时间

    # 日志文件路径
    access_log /Users/luoluqi/Desktop/ngnix-server/logs/access.log;
    error_log  /Users/luoluqi/Desktop/ngnix-server/logs/error.log warn;

    server {
        listen 8080;                               # 监听端口
        server_name localhost;                     # 本地访问域名

        root /Users/luoluqi/Desktop/blockify-ui/docs-dist; # 前端打包目录
        index index.html;

        # 单页面应用路由处理
        location / {
            try_files $uri $uri/ /index.html;
        }

        # 静态资源缓存
        location ~* .(js|css|png|jpg|jpeg|gif|svg|ico|woff2?|ttf|eot)$ {
            expires 30d;
            add_header Cache-Control "public";
        }

        # 禁止访问隐藏文件
        location ~ /. {
            deny all;
        }
    }
}

配置要点:

脚本化操作:nginx.sh

#!/bin/bash
BASE_DIR=$(cd "$(dirname "$0")"; pwd)
NGINX_CONF="$BASE_DIR/nginx.conf"

case "$1" in
  start)
    echo "Starting Nginx..."
    nginx -c "$NGINX_CONF"
    ;;
  reload)
    echo "Reloading Nginx configuration..."
    nginx -s reload
    ;;
  stop)
    echo "Stopping Nginx..."
    nginx -s stop
    ;;
  *)
    echo "Usage: ./nginx.sh {start|reload|stop}"
    exit 1
    ;;
esac

这样就不用每次手动敲 nginx -cnginx -s reload,直接 ./nginx.sh start 即可。

npm 脚本集成

package.json 里增加:

"scripts": {
  "nginx:start": "./nginx.sh start",
  "nginx:reload": "./nginx.sh reload",
  "nginx:stop": "./nginx.sh stop"
}

这样就可以用熟悉的 npm 命令来操作:

npm run nginx:start
npm run nginx:reload
npm run nginx:stop

总结:对前端的意义

建议:在团队中可以把这套配置放到前端仓库里(例如 nginx/ 文件夹),大家拉代码后就能直接启动,减少环境差异。

到此这篇关于Nginx搭建前端本地预览环境的完整步骤教学的文章就介绍到这了,更多相关Nginx搭建前端本地预览环境内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文