微信小程序之Promise-Promise初始用

我们来尝试使用Promise。

1、需求,做个抽奖的按钮,

抽奖规则:

30%的几率中奖,中奖会提示恭喜恭喜,奖品为10万 RMB 劳斯莱斯优惠券,没中奖会提示再接再厉。

2、先搭界面:

复制代码
<view class="title">抽奖规则:</view>
<view class="content">30%的几率中奖,中奖会提示恭喜恭喜,奖品为10万 RMB 劳斯莱斯优惠券,没中奖会提示再接再厉。</view>
<button class="btn" bind:tap="prizeDraw">开始抽奖</button>

3、css文件

复制代码
page {
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.btn{
  margin-top: 50rpx;
  color: black;
  border: 1px solid black;
}

.title{
  margin: 10rpx 40rpx;
  font-size: 50rpx;
  font-weight: 550;
}

.content{
  margin: 20rpx 80rpx;
  font-size: 40rpx;
}

3、实现prizeDraw函数。

复制代码
prizeDraw(){

    const p = new Promise((resolve,reject) => {

      setTimeout(() => {

        let n = Math.floor(Math.random()*100)+1;

        if (n <= 30) {

          resolve();

        } else {

          reject();

        }

      }, 1000);

    });



    p.then(() => {

      wx.showModal({

        title: '恭喜恭喜',

        content: '奖品为 10 万 RMB 劳斯莱斯优惠券',

        showCancel: false, // 隐藏取消按钮

        confirmText: '我知道了',

      });

    },() => {

      wx.showModal({

        title: '没抽中',

        content: '再接再厉',

        showCancel: false, // 隐藏取消按钮

        confirmText: '我知道了',

      });

    });

  }

代码说明:

a、const p = new Promise() ; //生成Promise对象。

b、里面有个参数,是函数,写法() => {}

c、函数里面有两个方法,resolve(解决)和reject(拒绝),函数里面的逻辑结果成功就调用resolve,失败就调用reject 。

d、然后运行Promise对象的then函数。

e、then里面带两个函数参数。

f、第一个用来执行成功的后续步骤,比如弹框之类,第二个用来执行失败的后续步骤

相关推荐
2501_9151063213 小时前
HTTPS 爬虫实战指南 从握手原理到反爬应对与流量抓包分析
爬虫·网络协议·ios·小程序·https·uni-app·iphone
2501_9160074713 小时前
iOS 上架技术支持全流程解析,从签名配置到使用 开心上架 的实战经验分享
android·macos·ios·小程序·uni-app·cocoa·iphone
阿登林13 小时前
如何利用扣子生成小程序并进行发布指南
小程序·扣子
全职计算机毕业设计14 小时前
基于微信小程序的运动康复中心预约系统的设计与实现(SpringBoot+Vue+Uniapp)
vue.js·spring boot·微信小程序
流***陌1 天前
手办盲盒抽赏小程序前端功能设计:兼顾收藏需求与抽赏乐趣
前端·小程序
Tencent_TCB1 天前
云开发CloudBase AI+实战:快速搭建AI小程序全流程指南
人工智能·ai·小程序·ai编程·云开发
说私域1 天前
“开源AI大模型AI智能名片S2B2C商城小程序”视角下的教育用户策略研究
人工智能·小程序
2501_916007471 天前
提升 iOS 26 系统流畅度的实战指南,多工具组合监控
android·macos·ios·小程序·uni-app·cocoa·iphone
一匹电信狗1 天前
【MySQL】数据库表的操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序
2501_915921431 天前
iOS 应用代上架流程,多工具组合与使用 开心上架 跨平台自动化上传指南
android·ios·小程序·uni-app·自动化·cocoa·iphone