From 6f821eb796db6f373f250d320e608764299961f8 Mon Sep 17 00:00:00 2001
From: shaogong <908634674@qq.com>
Date: Thu, 10 Oct 2024 22:28:18 +0800
Subject: [PATCH] =?UTF-8?q?feat:=20duxapp=E7=9B=B8=E5=85=B3=E6=96=87?=
=?UTF-8?q?=E6=A1=A3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
versioned_docs/version-3.x/composition.md | 7 +-
versioned_docs/version-3.x/duxapp.md | 231 +++++++++++++++++++
versioned_docs/version-3.x/treasures.md | 34 ++-
versioned_sidebars/version-3.x-sidebars.json | 1 +
4 files changed, 271 insertions(+), 2 deletions(-)
create mode 100644 versioned_docs/version-3.x/duxapp.md
diff --git a/versioned_docs/version-3.x/composition.md b/versioned_docs/version-3.x/composition.md
index c9e7c9d8d808..811abb4c89a2 100644
--- a/versioned_docs/version-3.x/composition.md
+++ b/versioned_docs/version-3.x/composition.md
@@ -11,7 +11,9 @@ title: 更多资源
- [Taro UI Vue3](https://b2nil.github.io/taro-ui-vue3/)
- [Taro UI Vue](https://github.com/psaren/taro-ui-vue)
- [基于 Taro + Taro-ui + Typescript + redux 开发的网易云音乐小程序](https://github.com/lsqy/taro-music)
-- [Taro Design 开源页面设计器](https://github.com/ShaoGongBra/taro-design)
+- [duxapp 兼容多端的模块化开发框架](https://duxapp.cn/)
+- [Taro 移动端页面设计器](https://github.com/duxapp/design)
+- [duxui 兼容 RN 的多端 UI 库](https://github.com/duxapp/duxui)
### Taro2
@@ -68,6 +70,9 @@ title: 更多资源
- [Taro 多端开发的正确姿势:打造三端统一的网易严选(小程序、H5、React Native)](https://juejin.im/post/5c6a151f518825625e4ac830)
- [Taro 与 Redux 结合使用教程](https://github.com/imageslr/taro-library#%E5%BC%95%E5%85%A5-redux)
- [微信小程序开发之影分身术](https://juejin.im/post/5c788d28e51d4560a82be8d2)
+- [用 duxapp 快速完成项目](https://duxapp.cn/blog/quick-prject)
+- [Taro 使用模块化开发,以提升开发效率](https://duxapp.cn/blog/intro)
+- [duxapp 对 RN 端开发进行了哪些改动,如何提升开发效率](https://duxapp.cn/blog/react-native)
## 视频教程
diff --git a/versioned_docs/version-3.x/duxapp.md b/versioned_docs/version-3.x/duxapp.md
new file mode 100644
index 000000000000..8ab4ed03bbe2
--- /dev/null
+++ b/versioned_docs/version-3.x/duxapp.md
@@ -0,0 +1,231 @@
+---
+title: 使用模块化项目开发框架
+---
+
+[duxapp](http://duxapp.cn)是基于 Taro 二次开发的模块化开发框架
+
+使用这个框架,结合框架提供的 UI 库和工具库,能帮助你快速且高质量的完成项目,且能实现同时开发小程序、H5、APP(React Native),并且保证各个端的一致性
+
+随着 Taro4.0 的推出和完善,duxapp 也将逐步完善对鸿蒙的支持
+
+:::info
+
+- 需要注意的是 duxapp 框架虽然是基于 Taro 开发的,但是他不能使用在你现有的项目中,因为 duxapp 对 Taro 的结构做了许多修改,你需要通过 duxapp 提供的 CLI 创建项目,而不是使用 Taro 的 CLI
+- 这篇文档仅介绍 duxapp 框架的特性,要使用 duxapp 框架请查看完整文档[duxapp.cn](http://duxapp.cn)
+ :::
+
+## 什么是模块化
+
+就像 npm 包一样,我们可以将一些通用的功能或页面编写在一个模块内,提供给多个项目来使用,以提高代码的复用性。
+
+模块的概念在很多后端框架中很常见,它们可以在应用商店通过安装应用的方式来获得新功能,在前端框架中确很少见到类似的设计方案,当然你其实也可以理解为发布到 npm 就是一种模块化的设计,但是在 Taro 中很多功能他并不能发布到 npm 中,例如页面。页面需要放在项目中,当发布到 npm 之后就会无法使用
+
+在 duxapp 框架中的模块化设计原理,和 npm 的依赖关系是类似的,每个模块有一个配置文件`app.json`,里面的依赖字段`dependencies`,用来填写我要用到的依赖,就像下面`ui库示例`这个模块的配置
+
+```jsx
+{
+ "name": "duxuiExample",
+ "description": "ui库示例",
+ "version": "1.0.13",
+ "dependencies": [
+ "duxui",
+ "duxcms",
+ "amap",
+ "echarts",
+ "wechat"
+ ]
+}
+```
+
+和 npm 依赖不一样的是,这里的依赖不包含版本信息。因为页面等限制条件,你一个项目中,同一个模块无法存在两个不同的版本,因此并未设计指定版本号的功能
+
+依赖关系是逐层查找的,就像 npm 一样,例如这里依赖的`duxui`模块,他的模块配置文件是这样的
+
+```json
+{
+ "name": "duxui",
+ "description": "DUXUI库",
+ "version": "1.0.42",
+ "dependencies": ["duxapp"],
+ "npm": {
+ "dependencies": {
+ "b-validate": "^1.5.3",
+ "react-native-view-shot": "~3.8.0",
+ "react-native-fast-shadow": "~0.1.1",
+ "array-tree-filter": "^2.1.0"
+ }
+ }
+}
+```
+
+在 duxui 模块中他又使用了`duxapp`这个依赖,通过每个模块都去查找,我们最终整理出这样的依赖关系图
+
+![dependencies]()
+
+那么最终当我们使用下面的命令编译`duxuiExample`模块的时候
+
+```bash
+# 调试小程序
+yarn dev:weapp --app=duxuiExample
+# 调试h5
+yarn dev:h5 --app=duxuiExample
+```
+
+实际被编译的模块就包含下面这些
+
+- duxuiExample
+- duxcms
+- amap
+- echarts
+- wechat
+- duxui
+- duxappReactNative
+- duxapp
+
+模块你可以将它当做项目、组件库、工具库,甚至是对某个第三方插件的封装,就像上面依赖里面的 `wechat`,他就是对微信插件的封装,这个模块在不同的端进行了不同的封装
+
+- 小程序:未使用第三方插件 封装了小程序的分享等功能
+- H5 封装了 JSSDK,你可以使用 jssdk 的功能,也封装了公众号分享
+- APP 封装了 `react-native-wechat-lib` 插件,用来实现微信相关功能
+
+那么当我们需要用到微信相关功能时,我们只需要在我们的模块依赖中添加 `wechat` 模块,重新编译就可以使用了
+
+:::info
+在 RN 端,当以依赖了 wechat 模块时,重新编译,会自动将 `react-native-wechat-lib` 这个原生插件打包到你的安装包中,你需要做的是在项目配置文件中配置微信插件需要的参数,如 APPID 等
+:::
+
+在 duxapp 提供的基础模块中还提供了很多基础组件和功能,像下面这些
+
+- [支持拦截器的网络请求](https://duxapp.cn/docs/course/started/net)
+- [支持拦截器的路由封装](https://duxapp.cn/docs/course/started/route)
+- [跨模块渲染钩子](https://duxapp.cn/docs/course/app/renderHook)
+- [多种方案的全局状态管理](https://duxapp.cn/docs/course/started/globalState)
+- [快速完成分页的列表组件](https://duxapp.cn/docs/course/started/list)
+- [主题系统](https://duxapp.cn/docs/course/app/theme)
+
+## 开发 APP(React Native)
+
+duxapp 还针对 APP 开发(React Native)做了大量优化,大大降低了 APP 发开的难度
+
+Taro 的 React Native 端开发提供了两种开发方式,一种是将壳和代码分离,一种是将壳和代码合并在一起开发
+
+duxapp 中更进一步,你不需要太关注壳子什么的,你只需要安装好安卓和 ios 的编译环境,用一个命令就能编译 apk 或者 ios,并且这个编译的过程和 duxapp 的模块化理念高度绑定,通过指定 `--app=` 指定不同的入口,就能打包出不同的项目,就像下面这样
+
+```bash
+# 编译 duxuiExample 的安卓调试版本
+yarn android --app=duxuiExample
+
+# 编译 duxuiExample 的IOS调试版本
+yarn ios --app=duxuiExample
+
+# 编译成功后启动Metro代码编译服务
+yarn start --app=duxuiExample
+```
+
+我们通过模块化+配置化来解决 RN 开发
+
+### 配置化
+
+对于 Taro 的壳子,或者原生 React Native,都会存在 `android` `ios`这两个文件夹,而在 duxapp 中,这些文件夹的内容是自动生成的,那么对于需要在这些文件夹中修改的配置内容,例如包名、版本号、新架构开关等,都通过配置文件的方式配置了,而不需要需修改具体的文件
+
+这个配置文件是项目配置文件夹下的 `configs/duxuiExample/duxapp.js`,其中 duxuiExample 就是我通过`--app=duxuiExample` 指定的入口模块
+
+这个配置文件的内容就像下面这样,可以清晰的看到,对安卓配置了包名、名称、版本号等信息,IOS 同样如此
+
+```js
+const config = {
+ android: {
+ appid: 'com.duxapp.duxui',
+ appName: 'duxUI库',
+ versionCode: 2,
+ versionName: '1.1.0',
+ keystore: {
+ storeFile: 'duxui.keystore',
+ keyAlias: 'duxui',
+ storePassword: 'TN62eyasJAKm2ksD',
+ keyPassword: 'TN62eyasJAKm2ksD',
+ },
+ },
+ ios: {
+ BundleId: 'com.duxapp.duxui',
+ appName: 'duxUI库',
+ versionCode: 1,
+ versionName: '1.0.0',
+ team: '',
+ plist: {
+ 'duxapp/Info.plist': {
+ NSCameraUsageDescription: 'duxUI库需要拍照用于APP内图片上传更换头像',
+ NSContactsUsageDescription: 'duxapp需要访问你的通讯录,将客户信息保存到通讯录中',
+ NSLocalNetworkUsageDescription: 'App需要访问你的本地网络,用于和服务器建立连接',
+ NSLocationAlwaysAndWhenInUseUsageDescription: '使用你的位置信息用于地图定位和位置选择',
+ NSLocationAlwaysUsageDescription: '使用你的位置信息用于地图定位和位置选择',
+ NSLocationWhenInUseUsageDescription: '使用你的位置信息用于地图定位和位置选择',
+ NSPhotoLibraryAddUsageDescription: 'duxUI库需要保存宣传图到你的相册用于分享',
+ NSPhotoLibraryUsageDescription: 'duxUI库需要访问相册用于APP内图片上传更换头像',
+ },
+ },
+ },
+}
+
+module.exports = config
+```
+
+### 内容复制
+
+上面这个配置文件已经解决了大部分打包需要用到的配置,但是你开发过 RN 的话你会看出来,证书他是一个文件,这里只指定了证书文件名称,但是并未指定证书具体内容,还有打包一个 app,它总是需要一个 app 图标的,包括安卓和 ios 的图标,那么这些内容,可以通过配置文件中的 copy 文件夹,将这些项目文件复制到安卓或者 ios 对应的文件位置
+
+[查看这个文档获取更多内容复制的信息](https://duxapp.cn/blog/react-native#%E5%86%85%E5%AE%B9%E5%A4%8D%E5%88%B6)
+
+### 三方插件
+
+你的项目或多或少都要用一些第三方的插件,`React Native`基础模块中已经包含了很多基础常用插件,你可以通过[三方模块](http://duxapp.cn/docs/app/duxappReactNative/start#三方模块)查看到,包含的基础插件
+
+传统的方法是将他们添加到 `package.json` 依赖中,然后根据文档内容修改安卓或者 ios 文件夹对应的内容,在 duxapp 中提供了另外一种方式来实现第三方插件的使用
+
+像这个`react-native-view-shot`安装方式很简单的插件,他只要求你将他添加到 `package.json` 的依赖中就可以使用了
+
+那么我们结合模块,在你需要用到这个功能的模块配置文件中,一样的添加上这个依赖即可,像下面这个`duxui`模块的配置文件一样
+
+```json
+{
+ "name": "duxui",
+ "description": "DUXUI库",
+ "version": "1.0.42",
+ "dependencies": ["duxapp"],
+ "npm": {
+ "dependencies": {
+ "b-validate": "^1.5.3",
+ "react-native-view-shot": "~3.8.0",
+ "react-native-fast-shadow": "~0.1.1",
+ "array-tree-filter": "^2.1.0"
+ }
+ }
+}
+```
+
+其实开源的大多数第三方插件都是这样的,只需要添加到依赖中,重新打包就能用了,但是很少数的插件,他就是要改一些安卓或者 ios 里面的原生内容,像微信插件,它需要的改动还挺多的
+
+你可以阅读这边文档,来了解微信插件是如何封装的 [三方模块](http://duxapp.cn/blog/react-native#%E4%B8%89%E6%96%B9%E6%A8%A1%E5%9D%97)
+
+## 多端 UI 库
+
+duxui 是 duxapp 官方开发的一款兼容多端的 UI 组件库,兼容小程序、H5、React Native,库中提供了 60+的组件,覆盖大部分使用场景
+
+它能帮助你通过统一的组件样式,快速完成多端应用的开发,包括 React Native 端的 APP 开发
+
+如果你想看到这些组件的展示效果,请根据不同的端进行查看
+
+- 小程序
+ ![小程序](https://duxapp.cn/assets/images/weapp-be9fc343794749aa3f8469086c263007.jpg)
+- APP [https://app.share.dux.plus/cn.duxapp.duxui](https://app.share.dux.plus/cn.duxapp.duxui)
+- H5 [https://duxui.duxapp.cn](https://duxui.duxapp.cn)
+
+如果你想通过项目来查看这些组件的运行效果或者组件源码,使用下面这个命令创建一个 UI 库的示例代码
+
+```bash
+npx duxapp-cli create projectName duxuiExample
+```
+
+其中的 `projectName` 是要创建的项目名称,创建之后根命令行据提示进行下一步操作
+
+UI 库开发文档[http://duxapp.cn/docs/duxui/start](http://duxapp.cn/docs/duxui/start)
diff --git a/versioned_docs/version-3.x/treasures.md b/versioned_docs/version-3.x/treasures.md
index c4f35f6e05d1..799dc02e8eee 100644
--- a/versioned_docs/version-3.x/treasures.md
+++ b/versioned_docs/version-3.x/treasures.md
@@ -232,6 +232,22 @@ Taro 小程序脚手架。 特性: 封装 api、redux 优雅集成、生成海
---
+### duxui
+
+`React`
+
+支持多端开发的 React 组件库
+
+@duxapp 出品。【[官网](https://duxapp.cn)】【[Github](https://github.com/duxapp/duxui)】
+
+
+
+| | 微信 | 京东 | 阿里系 | 百度 | 头条 | H5 | RN |
+| :----: | :--: | :--: | :----: | :--: | :--: | :-: | :-: |
+| 支持度 | ✔️ | | | | | ✔️ | ✔️ |
+
+---
+
### taro-ui-vue
`Vue`
@@ -674,7 +690,7 @@ Taro3 集成图表库 @visactor/vchart。
| | 微信 | 阿里系 | 百度 | 头条 | H5 | RN |
| :----: | :--: | :----: | :--: | :--: | :-: | :-: |
-| 支持度 | ✔️ | | | ✔️ | ✔️ | |
+| 支持度 | ✔️ | | | ✔️ | ✔️ | |
---
@@ -790,6 +806,22 @@ Taro 小程序路由库/自动生成带参数类型提示的路由方法/允许
---
+### 移动端页面编辑器
+
+`React`
+
+一个简单易用,方便扩展和集成的移动端页面编辑器。
+
+@duxapp 出品。【[官网](http://duxapp.cn/docs/app/design/start)】【[Github](https://github.com/duxapp/design)】
+
+
+
+| | 微信 | 阿里系 | 百度 | 头条 | H5 | RN |
+| :----: | :--: | :----: | :--: | :--: | :-: | :-: |
+| 支持度 | ✔️ | | | | ✔️ | ✔️ |
+
+---
+
### 表单可视化编辑
`React`
diff --git a/versioned_sidebars/version-3.x-sidebars.json b/versioned_sidebars/version-3.x-sidebars.json
index 38f9a584955e..cfbc8851033d 100644
--- a/versioned_sidebars/version-3.x-sidebars.json
+++ b/versioned_sidebars/version-3.x-sidebars.json
@@ -146,6 +146,7 @@
"css-modules",
"css-in-js",
"tailwindcss",
+ "duxapp",
"ossa",
"nutui",
"vant",