Taro 介绍
简介
Taro 是一套遵循 React 语法规范的 多端开发 解决方案。
现如今市面上端的形态多种多样,Web、React-Native、微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的时候,针对不同的端去编写多套代码的成本显然非常高,这时候只编写一套代码就能够适配到多端的能力就显得极为需要。
使用 Taro,我们可以只书写一套代码,再通过 Taro 的编译工具,将源代码分别编译出可以在不同端(微信/百度/支付宝/字节跳动/QQ 小程序、快应用、H5、React-Native 等)运行的代码。
特性
React 语法风格
Taro 遵循 React 语法规范,它采用与 React 一致的组件化思想,组件生命周期与 React 保持一致,同时支持使用 JSX 语法,让代码具有更丰富的表现力,使用 Taro 进行开发可以获得和 React 一致的开发体验。
代码示例
import Taro, { Component } from '@tarojs/taro'
import { View, Button } from '@tarojs/components'
export default class Index extends Component {
constructor() {
super(...arguments)
this.state = {
title: '首页',
list: [1, 2, 3],
}
}
componentWillMount() {}
componentDidMount() {}
componentWillUpdate(nextProps, nextState) {}
componentDidUpdate(prevProps, prevState) {}
shouldComponentUpdate(nextProps, nextState) {
return true
}
add = (e) => {
// dosth
}
render() {
return (
<View className="index">
<View className="title">{this.state.title}</View>
<View className="content">
{this.state.list.map((item) => {
return <View className="item">{item}</View>
})}
<Button className="add" onClick={this.add}>
添加
</Button>
</View>
</View>
)
}
}
由于微信小程序端的限制,有极少数 JSX 的优秀用法暂时不能得到很好地支持,同时,为了遵循 React 语法,Taro 在写法上也有一些自己的规范,具体可以参考:Taro 开发最佳实践 。
快速开发微信小程序
Taro 立足于微信小程序开发,众所周知小程序的开发体验并不是非常友好,比如小程序中无法使用 npm 来进行第三方库的管理,无法使用一些比较新的 ES 规范等等,针对小程序端的开发弊端,Taro 具有以下的优秀特性
✅ 支持使用 npm/yarn 安装管理第三方依赖
✅ 支持使用 ES7/ES8 甚至更新的 ES 规范,一切都可自行配置
✅ 支持使用 CSS 预编译器,例如 Sass 等
✅ 支持使用 Redux 进行状态管理
✅ 支持使用 MobX 进行状态管理
✅ 小程序 API 优化,异步 API Promise 化等等
支持多端开发转化
Taro 方案的初心就是为了打造一个多端开发的解决方案。目前 Taro 代码可以支持转换到 微信/百度/支付宝/字节跳动/QQ 小程序 、快应用、 H5 端 以及 移动端(React Native)。
社区共享
Taro 交流社区——让每一次交流都被沉淀 如果您在此文档没有找到想要的答案,请移步社区提问,我们会在看到的第一时间给予答复。
Taro 物料市场——让每一个轮子产生价值 如果您想找一些现成的物料,例如:模版、组件、SDK、UI,可以移步物料市场查找,也欢迎您发布物料与其他开发者共享。
Taro UI
一款基于 Taro
框架开发的多端 UI 组件库。
Taro UI 特性:
- 基于
Taro
开发 UI 组件 - 一套组件可以在
微信小程序
,支付宝小程序
,百度小程序
,H5
多端适配运行(ReactNative
端暂不支持) - 提供友好的 API,可灵活的使用组件
使用案例
Taro 已经投入了我们的生产环境中使用,业界也在广泛地使用 Taro 开发多端应用。
社区案例仅收纳了开发者主动提交的案例
学习资源
官方文章精选
- 使用 React Hooks 重构你的小程序
- Taro 1.3 震撼发布:全面支持 JSX 语法和 HOOKS
- 小程序框架全面测评
- Taro 在京东购物小程序上的实践
- 用 React 开发小程序的探索之路 (演讲内容整理)| 掘金开发者大会
- 为何我们要用 React 来写小程序 - Taro 诞生记
- 多端统一开发框架 - Taro 介绍
分享交流
其他
更多文章教程、开源项目等,请参考:awesome-taro
掘金小册:Taro 多端开发实现原理与实战 (已下架,仅购买用户可阅)
开发交流
扫码添加 凹凸实验室-小助手
,回复 Taro
即可进群。(Taro 开发交流 21 群 已满)