npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@byhealth/lottery

v1.2.42

Published

抽奖 [demo](http://www.eightfeet.cn/venomV2/dist/demo/index.html)

Downloads

110

Readme

lottery

抽奖 demo

parame

| | 参数名称 | 说明 | 是否必填 | 类型 | | ------------ | --------------------- | ------------------------------------------------------------ | -------- | ------------------------------------ | | 重要参数 | parentId | Game挂载Id游戏将要寄生的Node Id | 是 | String | | | targetId | Game自身Id默认game-target-时间戳+100以内随机数 | 否 | String | | | style | Game皮肤定义定义游戏模块的UI展示效果 | 是 | Object | | | prizes | 奖品参数参考prizes结构 | 是 | Array | | | start | 开始抽奖,向后台请求抽奖结果然后以promise的形式将结果返回给Game以启动抽奖。注意1、务必返回Promise对象2、中奖奖品数据结构必须等于prizes的某个子项 | 是 | Function()=>Promise(...) | | | saveAddress | 提交收货地址时保存收货人地址方法当所中奖品的属性receiveType=2(填写地址)时将会弹出地址填写框,完成地址填写提交后调用此方法用于保存收货人地址,参数address是收集的地址信息saveAddress = function(address){ console.log(data)} | 是 | Function()=>Promise(...) | | | playerPhone | 参与抽奖人的电话号码,有则显示 | 否 | String | | | checkVerificationCode | 获取短信验证码方法,用于短信验证参与人电话号码,有电话号码且有此方法时开启短信验证 | 否 | Function | | | receiverInfo | 默认收货人信息,中奖时此信息将自动填写到收货地址表单 | 否 | Object | | | cardIdRequest | 是否要求填写或验证身份证状态:1 隐藏身份证,2 验证身份证,3 身份证为空时不验证有填写时验证,4 不验证身份证 | 否 | Number | | | emBase | em基准像素,Game将把此值写入到parentId的style.fontSize中,子元素将以此为单位基准,默认计算window宽度 | 否 | Number | | | onCancel | 取消中奖结果或取消中奖后填写地址时的回调 | 否 | Function | | | onEnsure | 确定中奖结果或完成中奖填写地址时的回调 | 否 | Function | | | loading | 设置Loading的属性,也可以在style中设置document | 否 | Object | | 显示文字定义 | failedModalTitle | 未中奖弹窗标题 | 否 | String | | | submitFailedText | 未中奖按钮文字 | 否 | String | | | successModalTitle | 中奖弹窗标题 | 否 | String | | | submitSuccessText | 中奖按钮文字 | 否 | String | | | submitAddressText | 中奖去填写地址按钮文字 | 否 | String |

prizes 结构

奖品是一个数组,游戏将根据奖品数组渲染页面,奖品数组的每一项必须包含以下属性

prizes = [{
   "prizeId": 1, // 奖品id
   "prizeType": 1, // 奖品类型 0 未中奖, 1 实物, 2 虚拟
   "receiveType": 1, // 领取方式 1:默认;2:填写地址;3:链接类;4:虚拟卡
   "prizeAlias": "巴西绿蜂胶", // 奖品别名
   "prizeName": "蜂胶软胶囊彩盒装(60粒,巴西绿蜂胶)", // 奖品名称
   "awardMsg": null, // 中奖提示信息
   "gameImg": "./assets/images/card1.png", // 游戏图片
   "prizeImg": "./assets/images/prize1.jpg", // 奖品图片
   "memo": "奖品的备注说明!" // 奖品备注
},{...}]

case

import { Game } from '@byhealth/lottery/lib/roulette'; // roulette 大转盘, boxroulette 九宫格,flipcard 翻牌,dice 掷骰子,slotmachine 老虎机

const LotteryGame = new Game({
          targetId: "target",
          parentId: "parentId",
          playerPhone: "13635219421",
          cardIdRequest: 3, 
          style: window.themedata1,
          start: () => new Promise((resolve) => {
                window.LotteryGame1.Loading.show();
                window.setTimeout(() => {
                	window.LotteryGame1.Loading.hide();
                	resolve(prizes1[Math.floor(Math.random() * rand)]);
                }, 1000);
            }),
          saveAddress: data => new Promise((resolve) => {
                window.LotteryGame1.Loading.show();
                window.setTimeout(() => {
                    console.log('地址信息', data);
                	window.LotteryGame1.Loading.hide();
                	resolve();
                }, 3000);
            }),
          receiverInfo: {
              idCard: "430522201008124611",
              receiverPhone: "13622841234",
              address: "address"
          },
          checkVerificationCode: data => new Promise((resolve) => {
                window.LotteryGame1.Loading.show();
                window.setTimeout(() => {
                    console.log('手机验证码', data);
                	window.LotteryGame1.Loading.hide();
                	resolve();
                }, 3000);
            }), // 检查手机验证码
          prizes: {
			...
          },
          emBase: 10,
          onCancel: () => console.log('关闭中奖结果'),
          onEnsure: function(prize){ console.log('确定中奖结果1!', prize); },
          loading: {
            size: 20,
            length: 5,
            cycleTime: 1
          }
    });
    

to do list

  • [x] javaScript
  • [ ] change to typeScript