| Name | Date | Size | #Lines | LOC | ||
|---|---|---|---|---|---|---|
| .. | - | - | ||||
| AppScope/ | 22-Oct-2025 | - | 37 | 34 | ||
| entry/ | 22-Oct-2025 | - | 2,653 | 2,431 | ||
| feature/emitter/ | 22-Oct-2025 | - | 287 | 241 | ||
| hvigor/ | 22-Oct-2025 | - | 22 | 21 | ||
| screenshots/device/ | 22-Oct-2025 | - | ||||
| .gitignore | D | 22-Oct-2025 | 163 | 13 | 13 | |
| README_zh.md | D | 22-Oct-2025 | 4.2 KiB | 84 | 67 | |
| build-profile.json5 | D | 22-Oct-2025 | 1.1 KiB | 47 | 46 | |
| hvigorfile.ts | D | 22-Oct-2025 | 764 | 17 | 1 | |
| hvigorw | D | 22-Oct-2025 | 2.1 KiB | 62 | 28 | |
| hvigorw.bat | D | 22-Oct-2025 | 2 KiB | 72 | 56 | |
| oh-package.json5 | D | 22-Oct-2025 | 817 | 26 | 25 | |
| ohosTest.md | D | 22-Oct-2025 | 1.5 KiB | 15 | 11 |
README_zh.md
1# 自定义Emitter 2 3### 介绍 4 5本示例使用[Emitter](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-basic-services-kit/js-apis-emitter.md)实现事件的订阅和发布,使用[自定义弹窗](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-arkui/arkui-ts/ts-methods-custom-dialog-box.md)设置广告信息。 6 7### 效果预览 8 9|首页|列表页|详情内购买页面|购物车| 10|-------|-------|-------|-------| 11||||<img src="screenshots/device/shopping_cart.png" alt="shopping_cart" />| 12 13使用说明 141. 进入首页后弹出广告弹窗,点击即可关闭。 152. 点击商品列表中的一个商品可以跳转到商品详情页。 163. 在商品详情页点击首页可以返回到商品列表页,点击购物车可以跳转到购物车页面,点击加入购物车可以在购物车页面添加一条商品信息,点击立即购买可以增加一次已购物数量显示在购物车页面。 174. 在购物车页面点击购物车列表内商品的减号图标,可以将此商品信息从购物车列表内删除,点击清空购买数量可以将已购物数量清空、显示为0。 18 19### 工程目录 20``` 21entry/src/main/ets/ 22|---components 23| |---BottomNavigation.ets // 底部按钮导航栏 24| |---Choice.ets // 商品规格选择 25| |---EventsDialog.ets // 广告弹窗 26| |---Information.ets // 详细信息页面 27| |---Valueation.ets // 价格页面 28|---mock 29| |---DetailData.ets // 商品详情数据 30| |---ProductsData.ets // 产品列表数据 31|---model 32| |---DetailMode.ets // 商品详情数据结构 33| |---GoodsModel.ets // 商品数据结构 34|---pages 35| |---Detail.ets // 商品详情 36| |---Index.ets // 首页 37| |---ShopCart.ets // 购物车 38|---shoppingCart 39| |---Cart.ets // 购物车 40| |---FavorGoodlist.ets // 推荐列表 41|---util 42| |---Logger.ets // 日志工具 43feature/emitter/src/main/ets/ 44|---common 45| |---EmitterConst.ts // 事件通知常量 46|---components 47| |---feature 48| | |---CustomEmitter.ets // 封装事件通知类 49``` 50 51### 具体实现 52+ 订阅事件通知在CustomEmitter中实现,源码参考[CustomEmitter.ets](feature/emitter/src/main/ets/components/feature/CustomEmitter.ets) 53 + 广告弹窗:使用Emitter的事件单次订阅emitter.once(eventId,call),eventId为number类型,单次订阅CustomDialogController弹窗事件,弹窗触发后自动取消订阅。 54 + 关闭广告弹窗:使用Emitter的事件单次订阅emitter.once(eventId,call),eventId为string类型,单次订阅CustomDialogController弹窗事件,弹窗关闭后自动取消订阅。 55 + 购物车添加商品:使用Emitter.on持续订阅商品添加事件,eventId为number类型,添加商品时更新购物车商品列表。 56 + 购物车删除商品:使用Emitter.on持续订阅商品删除事件,eventId为string类型,删除商品时更新购物车商品列表。 57 + 购物数量:使用Emitter.getListenerCount获取购买事件订阅者数量,进入购物车页面显示数量结果,清空时取消订阅,结果为0。 58 59### 相关权限 60 61不涉及。 62 63### 依赖 64 65不涉及。 66 67### 约束与限制 68 691.本示例仅支持标准系统上运行,支持设备:RK3568; 70 712.本示例为Stage模型,支持API11版本SDK,版本号:4.1.3.5; 72 733.本示例需要使用DevEco Studio 3.1.1 Release (Build Version: 3.1.0.501, built on June 20, 2023)才可编译运行; 74 75### 下载 76如需单独下载本工程,执行如下命令: 77 78``` 79git init 80git config core.sparsecheckout true 81echo code/BasicFeature/Notification/CustomEmitter/ > .git/info/sparse-checkout 82git remote add origin https://gitee.com/openharmony/applications_app_samples.git 83git pull origin master 84```