使用taro开发微信小程序遇到的坑总结
taro,京东凹凸实验室出品的适配多端的一个框架,taro 是一套遵循 react 语法规范的 多端开发 解决方案。现如今市面上端的形态多种多样,web、react-native、微信小程序等各种端大行其道,当业务要求同时在不同的端都要求有所表现的时候,针对不同的端去编写多套代码的成本显然非常高,这时候只编写一套代码就能够适配到多端的能力就显得极为需要。
一.taro开发搭建
1.taro很方便就在于其环境搭建很轻松,照着官方文档几行代码就能搭建好。
2.在进行预览的时候,不同的方式区别是很大的!!!,写的什么就要用什么进行预览,不然真的是天差地别。(我踩的最傻屌的坑)
二.关于标签
1.在taro上目前我所用的所有标签都要事先声明,比如view,button,image等.如下声明
import { view, input, button ,image,text} from "@tarojs/components";
2.各个标签在使用时首字母都是大写,不大写是不规范的
3.特别注意微信小程序只识别view和text等,相当于于h5中的div,p标签等等
三.关于函数的书写
1.遵从react语法,直接上例子
changeheading(e) { this.setstate({ heading: e.detail.value }); }
四.关于taro本身自带标签
1.picker:
用于写滑动选择,选择日期啥的,非常方便 ,示例是选择时间的组件
state = { timesel: '12:01', } ontimechange = e => { this.setstate({ timesel: e.detail.value }) } <picker mode='time' onchange={this.ontimechange}> <view classname='arry'> {this.state.timesel} > </view> </picker>
2.opendata
在微信小程序中用于获取用户头像,昵称等信息,可以直接获取。
<opendata classname='avatar' type='useravatarurl'></opendata> //获取头像 <opendata classname='name' type='usernickname' lang='zh_cn'></opendata> // 获取昵称
3.其他的标签见taro官方文档。
五. 关于组件的引用
1.首先如何写一个组件
export default class 组件名 extends component { render(){ return() }
写时修改组件名,在引用时就可直接引用,例如
import 组件名 from '../../组件所在位置';
六.关于页面跳转
1.首先要在 app.js 的 page 里添加要管理的页面路径(即要跳转的页面路径)'pages/login/login',
2.然后在要跳转的页面写一个跳转方法就ok了
topage() { taro.navigateto({ url: '/pages/login/login', }) }
七.关于微信授权弹窗问题
wx.getuserinfo(object)此接口有调整,使用该接口将不再出现授权弹窗,请使用 引导用户主动进行授权操作,即该接口使用不在弹出授权窗口,只能使用button引导用户自己完成授权操作
那么现在就是通过wx.getsetting来判断用户是否授权,
如果授权直接获取相关信息跳转到相应页面
未授权的话就用button引导用户主动授权就ok了
八.taro上调用微信的方法
在微信中是wx.xxxxx,而在taro里可以直接用,只需要将前面的wx改成taro。
即wx.getsettting变成taro.getsetting。
总结
以上所述是小编给大家介绍的使用taro开发微信小程序遇到的坑总结,希望对大家有所帮助