微信小程序构建 npm 的坑

微信小程序构建 npm 的坑

前言

开发微信小程序时想使用 Vant Weapp,跟着文档构建 npm 一直失败,记录一下成功构建的步骤。

环境

系统:MacOS 14.2.1 (23C71)

微信开发者工具:Nightly 1.06.2401232

Node:v20.9.0

npm:10.1.0

模板:官方 TS + Sass - 基础模板

初始化环境

使用官方模板初始化环境:

由于笔者使用的是 TS ,因此初始化完成后可以看到已经存在package.json文件,其中安装了微信 api 的 TS 类型声明文件包:

(初始化的 name 居然是 miniprogram-ts-less-quickstart ,笔者明明选的是 sass ,真是粗心啊)

安装 Vant

根据 Vant Weapp 的文档安装:

sql 复制代码
 yarn add @vant/weapp --production

已经成功安装,出现了node_modules文件夹。

构建 npm

根据 Vant Weapp 的文档中的步骤三修改 project.config.json:

笔者的微信开发者工具应该算是新版,因此根据文档:

注意: 由于目前新版开发者工具创建的小程序目录文件结构问题,npm构建的文件目录为miniprogram_npm,并且开发工具会默认在当前目录下创建miniprogram_npm的文件名,所以新版本的miniprogramNpmDistDir配置为'./'即可

构建 npm :

然后提示错误:

这时候笔者摸不着头脑了已经,经过一番冲浪,看到了这个文章,原来是要重新打开项目...

重新打开项目(退出编辑器重新打开也可以),构建 npm 成功:

出现了miniprogram_npm目录。

测试

笔者在 index 页面中放置一个 van-button 测试一下:

分析报错信息,是因为开发者工具找组件的位置不对:

bash 复制代码
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/index/@vant/weapp/button/index 
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/index/@vant/weapp/button/index/index 
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/index/miniprogram_npm/@vant/weapp/button/index
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/index/miniprogram_npm/@vant/weapp/button/index/index
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/miniprogram_npm/@vant/weapp/button/index
 /Users/allen/code/demos/weapp-demo/miniprogram/pages/miniprogram_npm/@vant/weapp/button/index/index
 /Users/allen/code/demos/weapp-demo/miniprogram/miniprogram_npm/@vant/weapp/button/index
 /Users/allen/code/demos/weapp-demo/miniprogram/miniprogram_npm/@vant/weapp/button/index/index

而包安装位置是:

css 复制代码
 /Users/allen/code/demos/weapp-demo/miniprogram_npm/@vant

因此还是路径配置的问题,npm 构建的输出目录,并不在开发者工具的查找范围内。

找到project.config.json,进行修改:

json 复制代码
 {
   ...,
   "settings": {
     ...,
     "packNpmRelationList": [
       {
         "packageJsonPath": "./package.json",
         "miniprogramNpmDistDir": "./miniprogram"
       }
     ]
   },
   ...
 }

然后重新构建 npm:

可以看到,在miniprogram目录下新生成了miniprogram_npm目录,删除根目录下多余的miniprogram_npm目录。

可以看到van-button组件已经成功出现了。

总结

  1. 修改project.config.json后,如果构建 npm 失败,重新打开项目再试。
  2. Vant Weapp 文档快速上手步骤三中有一个注意,目前版本的开发者工具不需要根据注意进行修改。

如果不当之处,欢迎批评斧正。

相关推荐
忆往wu前18 分钟前
从0到1一步步拆解搭建,梳理一个 Vue3 简易图书后台全开发流程
前端·javascript·vue.js
木斯佳25 分钟前
前端八股文面经大全:字节抖音前端三面(2026-04-27)·面经深度解析
前端·面试·笔试·八股·面经
光影少年1 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs
Mr.mjw1 小时前
vue中封装一个环形进度条组件,根据外部盒子大小自适应变化
前端·javascript·vue.js
无心使然1 小时前
Openlayers调用ArcGis影像服务之一动态地图、地图切片(/exportImage)
前端·javascript·数据可视化
唯火锅不可辜负1 小时前
uniapp开发公众号订阅功能踩坑小记
前端·vue.js
opteOG2 小时前
游览器跨域问题详解
前端
SameX2 小时前
后台 GPS 记录从半天掉电 30% 到全天 8%,我的三版方案演进
前端
Cder2 小时前
用 React + Ink 在终端里「优雅搜索」:开源 CLI 设计与非交互模式实践
前端·agent
像我这样帅的人丶你还2 小时前
前端监控体系与实践(二):全局监控
前端·javascript·vue.js