理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事

理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事

目录

理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事

一、路径中 / 的含义

1、 / 所扮演的角色

2、根据 URL 中的 / 判断是目录还是资源

3、相对路径 vs 绝对路径

4、相对路径中的 . 与 ..

二、Vue中 / 的特殊作用

1、Vue Router 中的 /

2、Vue 项目构建时的 base 配置

三、SEO 对 / 的敏感性

四、Nginx 中 / 的配置技巧

五、fetch 和 API 请求中的 / 影响

六、正则表达式和字符串中的 / 与转义

七、结语


        作者:watermelo37

        ZEEKLOG万粉博主、华为云云享专家、阿里云专家博主、腾讯云、支付宝合作作者,全平台博客昵称watermelo37。

        一个假装是giser的coder,做不只专注于业务逻辑的前端工程师,Java、Docker、Python、LLM均有涉猎。



---------------------------------------------------------------------

温柔地对待温柔的人,包容的三观就是最大的温柔。

---------------------------------------------------------------------

理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事

        Web 开发中你一定见过 / —— 但它的用法可不仅仅是「斜杠」。这篇文章将全面梳理 / 在 JavaScript 和前端开发中的多种应用和语义,从文件路径到 API 请求,从浏览器资源引用到服务器配置,甚至涉及到转义、nginx配置和正则表达式。

一、路径中 / 的含义

1、 / 所扮演的角色

        在浏览器、Node、Vue CLI 中,/ 都表示一种层级关系,常用来分隔目录结构或路由片段:

  • /src/components/Button.vue → 组件文件路径
  • /api/user/info → RESTful API 路径
  • /about → 前端路由路径

2、根据 URL 中的 / 判断是目录还是资源

        浏览器会自动根据 URL 最后是否包含 / 来区分目录或文件资源,关键就在于是不是以 / 结尾,如果是,就代表最后一个路径名是目录名(文件夹名称),如果不是以 / 结尾,就是文件资源。

URL推断

/about/

目录

/about

文件资源(如 html、json)

/images/logo.png

文件资源

        /about/ → 被认为是目录,会尝试寻找 /about/index.html(vue中是寻找 /about/index.vue)

3、相对路径 vs 绝对路径

        一个表格讲清楚:

路径形式示例含义说明
绝对路径

/assets/logo.png

从网站根目录出发寻找资源
相对路径

./img/logo.png

当前文件夹下寻找资源
相对路径

../img/logo.png

当前文件夹的上一级目录下寻找资源

        vue 项目使用绝对路径的时候,/ 一般是从 public 文件夹开始往下,无法通过绝对路径访问src文件夹中的资源(一般用@,但是要配置),因为src下的资源在打包后会重新分配结构,使用绝对路径在生产环境就会失效,所以毫无意义。

4、相对路径中的 . 与 ..

  • .:当前路径(Current Directory)
  • ..:上一级目录(Parent Directory)
<!-- 当前文件在 /pages/about/index.html --> <img src="../../images/banner.jpg"> <!-- 实际路径为 /images/banner.jpg --> <!-- pages与iamges在同一目录下 -->

二、Vue中 / 的特殊作用

1、Vue Router 中的 /

        在Vue Router中,/ 代表根路由,也就是说实际路径为:协议+域名(ip+端口)+ baseUrl + 路由。最后的路由部分就是Vue Router配置的内容,根路由就是路由为 / 。

        此外/about/ 与 /about 默认被视为等价(除非手动设置)

const routes = [ { path: '/', component: Home }, { path: '/about', component: About }, ] 

2、Vue 项目构建时的 base 配置

        这个其实是要根据生产环境下的路由决定的,生产环境下的路由是什么,这里base就设置什么,以此来保证打包部署后的资源能被正确访问。

// vite.config.js export default defineConfig({ base: '/my-app/', // 所有资源前缀会带上这个路径 }) 

三、SEO 对 / 的敏感性

        搜索引擎(如 Google、Baidu)会把下面两个路径视为两个不同的页面

  • /blog
  • /blog/

        所以需要路由统一末尾加 /,或者通过 Nginx 重定向处理一致性,避免 /about 和 /about.html 指向同一页面而无重定向,容易造成 SEO 评分下降。

四、Nginx 中 / 的配置技巧

        proxy_pass 后的 / 会影响转发路径拼接方式,建议保持一致,否则可能造成路径错乱,此时 /api/user 实际会被转发至 http://localhost:3000/user。

        个人建议在nginx中永远在路径和路由后加上 / ,基本不会错。

location /api/ { proxy_pass http://localhost:3000/; } 

五、fetch 和 API 请求中的 / 影响

fetch('/api/user') // 相对根路径 fetch('./api/user') // 相对当前路径(可能出错) fetch('https://example.com/api/user') // 绝对路径 

        Vue 中推荐使用 axios 统一配置:

const instance = axios.create({ baseURL: '/api/', }) 

六、正则表达式和字符串中的 / 与转义

        在 JavaScript 正则表达式中,/ 是定界符,若路径中包含 /,需使用 \/ 进行转义。:

const reg = /\/api\/user/; // 匹配 "/api/user" 

        字符串中的 / 则不需要转义

const url = "https://example.com/api/user";

七、结语

        一个小小的 / 有这么多细节可以深挖, 是不是很有意思?如果你是前端开发者,理解 / 的这些细节能让你在写路径、调试接口、配置服务器、优化 SEO 时更游刃有余。

        只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

        其他热门文章,请关注:

        极致的灵活度满足工程美学:用Vue Flow绘制一个完美流程图

        你真的会使用Vue3的onMounted钩子函数吗?Vue3中onMounted的用法详解

        DeepSeek:全栈开发者视角下的AI革命者

        通过array.filter()实现数组的数据筛选、数据清洗和链式调用

        Web Worker:让前端飞起来的隐形引擎

        测评:这B班上的值不值?在不同城市过上同等生活水平到底需要多少钱?

        通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能

        TreeSize:免费的磁盘清理与管理神器,解决C盘爆满的燃眉之急

        通过MongoDB Atlas 实现语义搜索与 RAG——迈向AI的搜索机制

        深入理解 JavaScript 中的 Array.find() 方法:原理、性能优势与实用案例详解

        前端实战:基于Vue3与免费满血版DeepSeek实现无限滚动+懒加载+瀑布流模块及优化策略

        el-table实现动态数据的实时排序,一篇文章讲清楚elementui的表格排序功能

        JavaScript双问号操作符(??)详解,解决使用 || 时因类型转换带来的问题

        内存泄漏——海量数据背后隐藏的项目生产环境崩溃风险!如何避免内存泄漏

      【前端实战】如何让用户回到上次阅读的位置?

        MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver

        JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、DOM操作等

        高效工作流:用Mermaid绘制你的专属流程图;如何在Vue3中导入mermaid绘制流程图

Read more

Spring Boot 部署优化:打包体积缩小 80% 的秘诀

Spring Boot 部署优化:打包体积缩小 80% 的秘诀

✨道路是曲折的,前途是光明的! 📝 专注C/C++、Linux编程与人工智能领域,分享学习笔记! 🌟 感谢各位小伙伴的长期陪伴与支持,欢迎文末添加好友一起交流! 在微服务架构盛行的今天,Spring Boot 应用的打包体积直接影响着部署效率和资源成本。本文将分享如何通过一系列优化手段,将一个典型 Spring Boot 应用的打包体积从 150MB 缩减至 30MB,缩减幅度达 80%。 目录 * 问题背景 * 体积分析 * 优化策略 * 实战演示 * 效果对比 * 最佳实践 问题背景 典型场景 假设我们有一个标准的 Spring Boot Web 应用,包含以下依赖: # 项目依赖概览dependencies:- spring-boot-starter-web - spring-boot-starter-data-jpa - spring-boot-starter-security - spring-boot-starter-validation - mysql-connector-java - lombok

By Ne0inhk
2G 内存云服务器部署 Spring Boot + MySQL 实战:从踩坑到上线

2G 内存云服务器部署 Spring Boot + MySQL 实战:从踩坑到上线

2G 内存云服务器部署 Spring Boot + MySQL 实战:从踩坑到上线 前言 最近把自己的全栈博客项目部署到了腾讯云的入门级服务器(2核2G),过程中踩了不少坑。本文记录完整的部署过程和问题排查思路,希望对同样在小规格服务器上部署 Java 项目的同学有所帮助。 项目技术栈: * 后端:Java 17 + Spring Boot 3.2.3 + Spring Security + JPA * 数据库:MySQL 8.0 * 前端:Flutter Web * 反向代理:Nginx 1.26 * 容器:Docker 28.4 服务器配置: * 腾讯云轻量应用服务器 * 2 核 CPU / 2GB 内存 / 50GB

By Ne0inhk
告别适配难题:Oracle 迁移 KingbaseES SQL 语法快速兼容方案

告别适配难题:Oracle 迁移 KingbaseES SQL 语法快速兼容方案

引言 在数据库国产化替代的浪潮中,Oracle 迁移到 KingbaseES(金仓数据库)已经成为很多企业数字化转型的核心任务。而 SQL 语法适配是迁移过程中最关键的技术环节,直接影响项目效率、成本和系统稳定性。 KingbaseES 以内核级兼容为基础,Oracle 常用 SQL 语法的兼容度能达到 100%,就算有少量差异化场景,也有清晰可落地的适配方案,能帮企业实现“应用无感、平滑迁移”。下面结合官方兼容性文档和实际迁移案例,拆解 SQL 语法适配的核心要点、差异化场景解决方案和批量落地技巧,给数据库管理员和开发人员提供实用参考。 文章目录 * 引言 * 一、迁移前必懂:SQL 兼容性整体情况 * 二、核心适配场景:差异化语法解决方案(含代码示例) * (一)数据类型映射:大多零代码,特殊场景稍调整 * (二)函数差异:精准适配,语法大多兼容(含对比代码) * 1.

By Ne0inhk
如何利用简单的浏览器插件Web Scraper爬取知乎评论数据

如何利用简单的浏览器插件Web Scraper爬取知乎评论数据

一、简单介绍: Web Scraper 的优点就是对新手友好,在最初抓取数据时,把底层的编程知识和网页知识都屏蔽了,可以非常快的入门,只需要鼠标点选几下,几分钟就可以搭建一个自定义的爬虫。 我在过去的半年里,写了很多篇关于 Web Scraper 的教程,本文类似于一篇导航文章,把爬虫的注意要点和我的教程连接起来。最快一个小时,最多一个下午,就可以掌握 Web Scraper 的使用,轻松应对日常生活中的数据爬取需求。 像这样的网页数据,想要通过网页爬虫的方式获取数据,可以下载web scraper进行爬虫 这是常见的网页类型: 1.单页 单页是最常见的网页类型。 我们日常阅读的文章,推文的详情页都可以归于这种类型。作为网页里最简单最常见的类型,Web Scraper 教程里就拿豆瓣电影作为案例,入门 Web Scraper 的基础使用。 2.分页列表 分页列表也是非常常见的网页类型。 互联网的资源可以说是无限的,当我们访问一个网站时,不可能一次性把所有的资源都加载到浏览器里。现在的主流做法是先加载一部分数据,随着用户的交互操作(

By Ne0inhk