原生小程序一个按钮如何触发用户信息授权弹框 和 手机授权 弹框?

现在页面上有一个按钮,点击之后,希望提示用户同时授权“用户信息”、“手机号码”,但是一个按钮只能有一个 open-type 属性,该如何处理呢?

<button @tap='signIn' open-type="getPhoneNumber" @getphonenumber="getPhoneNumber">微信登录</button>
    getPhoneNumber (e) {
      let postDatas = e.detail

      Taro.getUserInfo({
        success: (res) => {
          //待调试
          wx.login({
            success: res3 => {
              postDatas.code = res3.code
              console.log(postDatas)
              api.getPhoneNumber(postDatas).then(res2 => {
                setStorageSync('phoneNumber', res2.phoneNumber || '')
              })
            }
          })
        }
      })
    },
    signIn() {
      Taro.getUserProfile({ //可以弹用户授权框
        desc:'正在获取',//不写不弹提示框
        success: (res) => {
          
        }
      })
    },
阅读 4.2k
1 个回答

没办法,现在就得分两步进行,必须先授权登录拿个人信息、再授权绑定手机号,你看哪个小程序可以可以同时授权俩了?

taro 代码如下:

<button @tap='signIn' open-type="getPhoneNumber" @getphonenumber="getPhoneNumber">微信登录</button>
getPhoneNumber (e) {
      let postDatas = e.detail

      Taro.getUserInfo({
        success: (res) => {
          //待调试
          wx.login({
            success: res3 => {
              postDatas.code = res3.code
              console.log(postDatas)
              api.getPhoneNumber(postDatas).then(res2 => {
                setStorageSync('phoneNumber', res2.phoneNumber || '')
              })
            }
          })
        }
      })
    }
    signIn() {
      let openId = getOpenId()

      //没有授权信息
      if(!openId) {
        //弹出授权框
        Taro.getUserProfile({
          desc:'正在获取',//不写不弹提示框
          success: (res) => {
            //用户授权,储存授权信息
           
          },

        })
      }
    },
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏