微信小程序中,import 两种路径引入方式的区别和使用场景

在微信小程序中,import 语句用于引入模块,路径的写法会影响模块的正确导入。以下是两种路径引入方式的区别和使用场景:

1、 相对路径 (import { formatTimestamp } from ".../.../.../utils/util")

解释

  • 相对路径是相对于当前文件所在目录的路径。
  • .../.../.../utils/util 表示从当前文件向上移动三个目录,然后进入 utils 目录,最后引入 util.js 文件。

假设你的文件结构如下

miniprogram/

├── pages/

│ ├── message/

│ │ ├── message-list/

│ │ │ ├── message-list.js

│ │ │ └── .../.../.../utils/util.js

│ └── app.js

在 message-list/message-list.js 文件中,你需要向上移动三层目录才能找到 utils/util.js 文件。因此,使用相对路径 .../.../.../utils/util 是合适的。

优点

直观地反映了文件系统中的实际路径。

可以在多级目录结构中精确控制路径。

缺点

如果目录结构变化,路径可能需要相应地调整。

相对路径较长时,可能会变得难以维护。

2、绝对路径 (import { formatTimestamp } from "miniprogram/utils/util"😉

解释

  • 绝对路径是从项目根目录或指定的根路径开始的路径。
  • miniprogram/utils/util 表示从项目的根目录开始查找 miniprogram/utils/util.js 文件。

如果你的项目配置了绝对路径,且 miniprogram 是根目录下的一个目录,那么 import { formatTimestamp } from "miniprogram/utils/util"; 是有效的。

优点

路径更简洁,尤其是当文件层级较深时。

更易于维护和阅读。

缺点

-- 需要确保项目配置支持绝对路径解析。微信小程序默认不支持绝对路径,需要配置 jsconfig.json 或 tsconfig.json 来支持这种路径。

-- 如果项目结构发生变化,可能需要重新配置路径映射。

配置绝对路径(在微信小程序中)

微信小程序默认不支持绝对路径。如果你想使用绝对路径,可以在 jsconfig.json 或 tsconfig.json 中配置路径别名(如果你的开发工具支持)。

jsconfig.json

{

"compilerOptions": {

"baseUrl": "miniprogram", // 设置根目录

"paths": {

"utils/": ["utils/ "]

}

}

}

3、总结

  • 相对路径(例如 .../.../.../utils/util)从当前文件的位置计算,适用于大多数项目结构。
  • 绝对路径(例如 miniprogram/utils/util)从项目根目录计算,简洁且易于维护,但需要配置支持。

在使用绝对路径时,确保你的开发环境或工具支持这种路径映射,否则推荐使用相对路径来确保模块能够正确引入。

相关推荐
知识分享小能手1 小时前
uni-app 入门学习教程,从入门到精通,uni-app 企业项目实战:鲁嗑瓜子项目开发知识点(9)
前端·javascript·学习·微信小程序·小程序·uni-app·vue
知识分享小能手1 小时前
uni-app 入门学习教程,从入门到精通,uni-app中uCharts组件学习((8)
vue.js·学习·ui·微信小程序·小程序·uni-app·echarts
社会底层无业大学生3 小时前
uniapp微信小程序简单表格展示
微信小程序·小程序·uni-app·vue·1024程序员节
從南走到北4 小时前
JAVA无人自助共享系统台球室源码自助开台约球交友系统源码小程序
java·微信·微信小程序·小程序·1024程序员节
2501_915918417 小时前
iOS 26 查看电池容量与健康状态 多工具组合的工程实践
android·ios·小程序·https·uni-app·iphone·webview
2501_915909068 小时前
iOS 架构设计全解析 从MVC到MVVM与使用 开心上架 跨平台发布 免Mac
android·ios·小程序·https·uni-app·iphone·webview
2501_9160088918 小时前
Web 前端开发常用工具推荐与团队实践分享
android·前端·ios·小程序·uni-app·iphone·webview
2501_9159214318 小时前
“HTTPS 个人化”实战,个人站点与设备调试的部署、验证与抓包排查方法
网络协议·http·ios·小程序·https·uni-app·iphone
菜鸟una19 小时前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
韩立学长20 小时前
【开题答辩实录分享】以《租房小程序的设计和实现》为例进行答辩实录分享
java·spring boot·小程序