![Taro多端开发权威指南:小程序、H5与App高效开发实战](https://wfqqreader-1252317822.image.myqcloud.com/cover/719/38209719/b_38209719.jpg)
1.3 开发环境及工具介绍
Taro项目开发依赖Node.js环境,并且要求Node.js版本高于8.0.0,Taro允许使用大多npm中的库,支持更友好的第三方依赖管理。如果你刚接触Taro,那么推荐使用Taro提供的脚手架工具创建项目,同时该工具提供了很多功能,譬如诊断依赖、创建模块、更新包、打包构建等。我们就从安装Taro脚手架开始吧!
1.3.1 安装Taro脚手架工具
你可以选用npm或者Yarn全局安装@tarojs/cli,或者使用npx。不过由于Node.js版本限制等问题,推荐使用nvm这一工具来管理Node.js版本。
使用npm全局安装Taro脚手架:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_33_1.jpg?sign=1739138383-VEdIISnYte9EQxQHaobQucwGpR9IlD0m-0-4e682df8c85e0bb7b5ac9f8d8660b8a1)
使用Yarn全局安装Taro脚手架:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_33_2.jpg?sign=1739138383-cUUMJUBFdyMFkd1Ok3ygz6zJBAmGdvxg-0-1a17537b88fc5105cfdb642eac336d36)
安装过程可能会提示Sass相关依赖安装错误,这时请终止,然后手动安装mirror-config-china后重试。安装命令如下:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_33_3.jpg?sign=1739138383-cZqWnsMU5OCYt3ITMOshTCLCItYfwzvP-0-11c40ac1b249c182848509e877175d06)
1.3.2 初始化项目
上一节已经成功安装Taro脚手架工具,现在只需一行命令就能创建出基础Taro项目了,命令如下:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_33_4.jpg?sign=1739138383-DXOYCH1se4uY30wFezAoBUYHourfcc2I-0-de9d63bc49115154d806e7585acdac4a)
如果你的npm版本大于5.2,则可以直接使用npx创建项目:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_33_5.jpg?sign=1739138383-fq7mofFXkPvUXzYaNdl56Capq8pBqwlw-0-26133d21f4a08d636ebef3b3f08933c0)
项目模板及相关配置文件创建完成以后,Taro会自动安装项目中所需要的相关依赖。为了提升安装速度,Taro内部会为我们按照Yarn、cnpm、npm的顺序检测并选择更快的方式去安装依赖。如果在依赖安装过程中出现错误导致安装终止,则可以进入项目的根目录尝试手动安装。
1.3.3 运行项目
Taro开发环境的启动命令较多,分别对应不同端的代码编译与调试,但是为了更方便记忆与语义化,Taro定义了相对一致的开发环境启动命令,以npm运行命令为例,如下表所示。
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_34_1.jpg?sign=1739138383-3UFW74duuqOj8KJ9zSxqXbmckUs5nqE1-0-b39cc3e89f26e0825f8c2024465a8518)
通过以上命令,可以将Taro项目编译为不同端开发环境的代码。这时,只需要使用各端(除了H5)对应的开发工具,打开编译生成的项目文件,即可预览调试。以微信小程序为例:
(1)运行针对微信小程序的编译命令:npm run dev:weapp。
(2)使用微信小程序开发工具,打开该项目目录下的dist文件夹,即可在微信小程序开发者工具中进行预览与调试。
如果你需要同时调试预览多端应用,则需要修改项目下的config/index.js文件,配置outputRoot参数:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_34_2.jpg?sign=1739138383-B3zx4kyROgt9Z6ji95Tvsb8zTXzjCGdM-0-363725380a6842deceefc8499c69973a)
注:Taro 1.3.5+支持该配置,请确保项目中各端打包与编译相关的依赖版本和@tarojs/cli版本一致。
1.3.4 打包项目
Taro的打包命令同样有多个,也分别对应不同端的线上环境代码生成。为了方便记忆与语义化,Taro定义了相对一致的打包线上环境的代码命令,以npm为例,如下表所示。
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_35_1.jpg?sign=1739138383-EBgTrKc6vaGbdxdMK1Yqt2ACaIAmOOhy-0-00635e34a6bb8dab0e823a5c97dfd701)
通过以上命令,可以将Taro项目编译为不同端线上环境的代码,这时只需要使用各端(除了H5)对应的开发工具发布项目即可。打包生成线上环境的代码相较运行本地开发环境的代码,做了更多优化相关的处理,例如JavaScript代码压缩丑化等。
1.3.5 Taro脚手架命令
Taro脚手架提供了很多功能辅助我们开发,可使用taro--help查看Taro脚手架工具的相关提示。这里给大家讲解开发过程中常使用的几个命令,更多命令可前往Taro官网查看学习。
1.更新——update
该命令用来更新项目中的Taro相关依赖或者更新自身的脚手架工具。
更新项目依赖:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_36_1.jpg?sign=1739138383-VaLF3AZuC6NgfOl48fxArTPXJTbVioeY-0-08306b3161d23177138ef629b3181d48)
如果用以上方法更新项目依赖失败,则可尝试修改package.json文件指定对应的依赖版本,然后使用npm或Yarn手动安装。
更新脚手架:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_36_2.jpg?sign=1739138383-TwJXO3v5hZdz86fWzsPC5SsyoMjp3oZb-0-0d72eb855e5252f49124116bfb8fc496)
注:以上[version]为选填项,通过执行对应的版本号,安装或更新至对应的版本。
2.环境及依赖信息——info
该命令用来检测Taro环境及依赖的版本等信息,从而方便开发者查看项目环境及依赖,更便捷地排查因开发环境引起的问题。用法如下:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_36_3.jpg?sign=1739138383-ClgjsNwSz6bTZVWNZLLpkwgQ1VNu6jxf-0-e3e223fbf891d0f5c75de98c83490239)
命令执行完毕,会打印出项目的相关信息,示例如下:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_36_4.jpg?sign=1739138383-ab8S9g7QJwAqpvww9TDEvc3SHS3dfeBg-0-d3386cd8359cf0be86f0f876ab62c083)
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_37_1.jpg?sign=1739138383-IwsC27cAcuOXn0BUltFw94QbSEimlBNo-0-21f76caf41bec5733d36669d5905eb9b)
这样一来,我们可以发现当前使用的Taro脚手架工具版本为2.2.4。但项目中的依赖版本却是2.1.6,此时需要更新项目依赖,以保证与Taro脚手架工具版本一致,更新命令为:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_37_2.jpg?sign=1739138383-hQSnPpeFKAAIeU8QZeM8zmVoxSYqkSBE-0-5ce5f9aa73144f580e5be3cfc9de6efa)
3.项目诊断——doctor
该命令可以诊断项目的依赖、设置、结构及代码的规范是否存在问题,诊断结束后会尝试给出对应问题的解决方案。使用示例如下:
![](https://epubservercos.yuewen.com/D79B16/20118172101010406/epubprivate/OEBPS/Images/40906_37_3.jpg?sign=1739138383-vDdH3y18ko09O9XYQnigzRC7ewjlqCWK-0-b29ca3924803dcc991b4d689643cf3e9)