欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用taro开发微信小程序遇到的坑总结

程序员文章站 2022-05-16 11:15:08
taro,京东凹凸实验室出品的适配多端的一个框架,taro 是一套遵循 react 语法规范的 多端开发 解决方案。现如今市面上端的形态多种多样,web、react-nat...

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开发微信小程序遇到的坑总结,希望对大家有所帮助