一、关于taro
taro是来自京东开发的一款一套代码,多端运行的框架,并且语法类似于react(个人喜欢react是因为他是一个库,而不是一个框架,随意搭配,以及函数式编程。)
二、关于taro学习文档
taro官方文档
三、关于taro的使用
使用taro前还是需要安装一个,taro的cli工具,安装命令
代码语言:javascript复制npm install -g @tarojs/cli
关于taro安装过程中可能会出现sass
的安装错误情况,个人推荐尽量使用npm
进行安装,cnpm
经常会出现sass
安装错误的情况
如果安装出错的话,可以使用以下命令
npm install -g mirror-config-china
快速创建项目
代码语言:javascript复制taro init projectName
之后会出现一个项目配置的选项,按照常用的配置进行选择就可以了
四、开发
安装好项目以后,就可以开始开发了,基本上原来wx
开头api
的都可以换成taro
开头进行使用,像开发react
一样开发小程序,基本上没有什么坑。和react开发不同点是,react
提倡的是一切皆组件,但是taro为了兼容小程序,所以还是按照小程序来的,页面是页面,组件是组件。还新增了一些生命周期:新增生命周期
五、taro中注意事项
- 当传递props的值是函数时,必须在用on 函数名的规范来命名,否则子组件无法获取到所传递的函数。
- taro可以兼容很多端,但是如果要兼容reactNative端的话,建议先看看下面这个链接,因为reactNative的限制比较多
- 关于taro convert,taro可以将小程序代码转化成react,进行二次开发。但是这里有坑,很多人写小程序,喜欢不在data里面写数据,而在请求之后setData写数据,如果这样的行为使用taro convert转成react的话,参数是获取不到的。
六、耗费一周的结果
下面是耗费一周自导自演开发的一款小程序,目前已有数家公司使用,包括服务通知,公众号的消息提示功能等等,还是挺完善的。
七、 关于ReactNative
不建议taro兼容reactNative进行开发,因为reactNative适配很麻烦,开发app建议试试刚出来不久的flutter,虽然现在的flutter不及reactNative,但是flutter才刚出来,Flutter 基于GPU渲染,高性能,最高支持120fps,甚至不亚于原生app,flutter还可以用来开发游戏,而reactNative则不行。