BAT 小程序、H5 与 RN 端统一框架Taro

现如今市面上端的形态多种多样,Web、React-Native、微信小程序等各种端大行其道。当业务要求同时在不同的端都要求有所表现的时候,针对不

简介

Taro 是一套遵循 React 语法规范的 多端开发 解决方案。现如今市面上端的形态多种多样,Web、React-Native、微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的时候,针对不同的端去编写多套代码的成本显然非常高,这时候只编写一套代码就能够适配到多端的能力就显得极为需要。

使用 Taro,我们可以只书写一套代码,再通过 Taro 的编译工具,将源代码分别编译出可以在不同端(微信/百度/支付宝/字节跳动小程序、H5、React-Native 等)运行的代码。

Taro 特性

React 语法风格

Taro 的语法规则基于 React 规范,它采用与 React 一致的组件化思想,组件生命周期与 React 保持一致,同时在书写体验上也尽量与 React 类似,支持使用 JSX 语法,让代码具有更丰富的表现力。

代码示例

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>
 )
 }
}

快速开发微信小程序

Taro 立足于微信小程序开发,众所周知小程序的开发体验并不是非常友好,比如小程序中无法使用 npm 来进行第三方库的管理,无法使用一些比较新的 ES 规范等等,针对小程序端的开发弊端,Taro 具有以下的优秀特性:

  • 支持使用 npm/yarn 安装管理第三方依赖。
  • 支持使用 ES7/ES8 甚至更加新的 ES 规范,一切都可自行配置。
  • 支持使用 CSS 预编译器,例如 Sass 等。
  • 支持使用 Redux 进行状态管理。
  • 支持使用 Mobx 进行状态管理。
  • 小程序 API 优化,异步 API Promise 化等等。

支持多端开发转化

Taro 方案的初心就是为了打造一个多端开发的解决方案。目前 Taro 代码可以支持转换到 微信/百度/支付宝/字节跳动小程序H5 端 以及 移动端(React-Native)

BAT 小程序、H5 与 RN 端统一框架Taro

项目地址

https://github.com/NervJS/taro

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/10273.html

(0)
上一篇 2023年 4月 22日 下午11:57
下一篇 2023年 4月 22日 下午11:57

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信