{"id":18938203,"url":"https://github.com/wechat-miniprogram/miniprogram-custom-component","last_synced_at":"2025-04-06T06:06:51.464Z","repository":{"id":45795978,"uuid":"145291186","full_name":"wechat-miniprogram/miniprogram-custom-component","owner":"wechat-miniprogram","description":null,"archived":false,"fork":false,"pushed_at":"2021-04-29T09:32:44.000Z","size":77,"stargazers_count":201,"open_issues_count":6,"forks_count":40,"subscribers_count":12,"default_branch":"master","last_synced_at":"2025-03-26T12:41:30.341Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/wechat-miniprogram.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-08-19T09:53:29.000Z","updated_at":"2025-03-21T08:14:03.000Z","dependencies_parsed_at":"2022-07-17T01:30:31.653Z","dependency_job_id":null,"html_url":"https://github.com/wechat-miniprogram/miniprogram-custom-component","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wechat-miniprogram%2Fminiprogram-custom-component","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wechat-miniprogram%2Fminiprogram-custom-component/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wechat-miniprogram%2Fminiprogram-custom-component/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/wechat-miniprogram%2Fminiprogram-custom-component/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/wechat-miniprogram","download_url":"https://codeload.github.com/wechat-miniprogram/miniprogram-custom-component/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":247441043,"owners_count":20939239,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-11-08T12:13:42.690Z","updated_at":"2025-04-06T06:06:51.441Z","avatar_url":"https://github.com/wechat-miniprogram.png","language":"JavaScript","readme":"# miniprogram-custom-component\n\n小程序自定义组件开发模板：\n\n* 支持使用 less 语法编写 wxss 文件\n* 使用 webpack 构建 js\n* 支持自定义组件单元测试\n* 支持 eslint\n* 支持多入口构建\n\n## 使用\n\n* 使用[命令行工具](https://github.com/wechat-miniprogram/miniprogram-cli)进行初始化\n* 直接从 github 上 clone 下来\n\n## 开发\n\n1. 安装依赖：\n\n```\nnpm install\n```\n\n2. 执行命令：\n\n```\nnpm run dev\n```\n\n默认会在包根目录下生成 miniprogram\\_dev 目录，src 中的源代码会被构建并生成到 miniprogram\\_dev/components 目录下。如果需要监听文件变化动态构建，则可以执行命令：\n\n```\nnpm run watch\n```\n\n\u003e ps: 如果 minirpogram\\_dev 目录下已存在小程序 demo，执行`npm run dev`则不会再将 tools 下的 demo 拷贝到此目录下。而执行`npm run watch`则会监听 tools 目录下的 demo 变动并进行拷贝。\n\n3. 生成的 miniprogram\\_dev 目录是一个小程序项目目录，以此目录作为小程序项目目录在开发者工具中打开即可查看自定义组件被使用的效果。\n\n4. 进阶：\n\n* 如果有额外的构建需求，可自行修改 tools 目录中的构建脚本。\n* 内置支持 webpack、less 语法、sourcemap 等功能，默认关闭。如若需要可以自行修改 tools/config.js 配置文件中相关配置。\n* 内置支持多入口构建，如若需要可自行调整 tools/config.js 配置文件的 entry 字段。\n* 默认开启 eslint，可自行调整规则或在 tools/config.js 中注释掉 eslint-loader 行来关闭此功能。\n\n## 发布\n\n\u003e ps: 发布前得确保已经执行构建，小程序 npm 包只有构建出来的目录是真正被使用到的。\n\n1. 如果还没有 npm 帐号，可以到[ npm 官网](https://www.npmjs.com/)注册一个 npm 帐号。\n2. 在本地登录 npm 帐号，在本地执行：\n\n```\nnpm adduser\n```\n\n或者\n\n```\nnpm login\n```\n\n3. 在已完成编写的 npm 包根目录下执行：\n\n```\nnpm publish\n```\n\n到此，npm 包就成功发布到 npm 平台了。\n\n\u003e PS：一些开发者在开发过程中可能修改过 npm 的源，所以当进行登录或发布时需要注意要将源切回 npm 的源。\n\n## 目录结构\n\n以下为推荐使用的目录结构，如果有必要开发者也可以自行做一些调整:\n\n```\n|--miniprogram_dev // 开发环境构建目录\n|--miniprogram_dist // 生产环境构建目录\n|--src // 源码\n|   |--components // 通用自定义组件\n|   |--images // 图片资源\n|   |\n|   |--xxx.js/xxx.wxml/xxx.json/xxx.wxss // 暴露的 js 模块/自定义组件入口文件\n|\n|--test // 测试用例\n|--tools // 构建相关代码\n|   |--demo // demo 小程序目录，开发环境下会被拷贝生成到 miniprogram_dev 目录中\n|   |--config.js // 构建相关配置文件\n|\n|--gulpfile.js\n```\n\n\u003e PS：对外暴露的 js 模块/自定义组件请放在 src 目录下，不宜放置在过深的目录。另外新增的暴露模块需要在 tools/config.js 的 entry 字段中补充，不然不会进行构建。\n\n## 测试\n\n* 执行测试用例：\n\n```\nnpm run test\n```\n\n* 执行测试用例并进入 node inspect 调试：\n\n```\nnpm run test-debug\n```\n\n* 检测覆盖率：\n\n```\nnpm run coverage\n```\n\n测试用例放在 test 目录下，使用 **miniprogram-simulate** 工具集进行测试，[点击此处查看](https://github.com/wechat-miniprogram/miniprogram-simulate/blob/master/README.md)使用方法。在测试中可能需要变更或调整工具集中的一些方法，可在 test/utils 下自行实现。\n\n## 其他命令\n\n* 清空 miniprogram_dist 目录：\n\n```\nnpm run clean\n```\n\n* 清空 miniprogam_dev 目录：\n\n```\nnpm run clean-dev\n```\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwechat-miniprogram%2Fminiprogram-custom-component","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fwechat-miniprogram%2Fminiprogram-custom-component","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwechat-miniprogram%2Fminiprogram-custom-component/lists"}