WebApp快捷打包
Bloom 广告(AD)
转到模块插件

敬告:此 DEMO 演示为开放测试页面,仅用于开发者快速测试体验应用功能,请严格遵守开发者协议,了解更多

JS-SDK 引用方式:

♦ 普通网页 script 方式加载:下载最新版 jsBridge-v20241115.zip,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库;

♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package

Bloom 广告(AD)

config 配置

jsBridge.bm.config({
  //广告 APP ID
  //可在打包模块里面配置,以此 js 接口的配置值优先
  app_id : "ba0063bfbc1a5ad878",
  //可选,用户ID,后期可调用 setUserId 设置
  user_id: "13800138000"
}, function(succ, data) {
  alert(succ ? "成功" : "失败:" + JSON.stringify(data));
});

事件监听

setListener 设置监听器

• 如需接口调用事件,请设置此监听器;

jsBridge.bm.setListener(function(event, data) {
    switch (event) {
        //激励视频 jsBridge.bm.rewardVideoAd(...)
        case "RewardVideoAd": {
            switch (data.action) {
                //广告加载成功
                case "onAdLoad": {
                    //事件参数 data.message
                    break;
                }
                //视频素材缓存成功
                case "onVideoCached": {
                    break;
                }
                //广告页面展示
                case "onAdShow": {
                    break;
                }
                //广告奖励有效性回调,onReward 一定在 onAdClose 之前,但不保证与 onVideoComplete 的先后顺序,建议在 onAdClose 中判断 onReward 已回调才给用户奖励
                case "onReward": {
                    break;
                }
                //广告被点击
                case "onAdClick": {
                    break;
                }
                //广告播放完毕
                case "onVideoComplete": {
                    break;
                }
                //广告被关闭
                case "onAdClose": {
                    break;
                }
                //广告出错
                case "onError": {
                    break;
                }
                //播放出错(仅支持 iOS)
                case "onAdPlayError": {
                    break;
                }
            }
            break;
        }
        //插屏广告 jsBridge.bm.interstitialAd(...)
        case "InterstitialAd": {
            switch (data.action) {
                //广告加载成功
                case "onAdLoad": {
                    break;
                }
                //广告页面展示
                case "onAdShow": {
                    break;
                }
                //广告被点击
                case "onAdClick": {
                    break;
                }
                //广告被关闭
                case "onAdClose": {
                    break;
                }
                //广告出错
                case "onError": {
                    break;
                }
            }
            break;
        }
        //横幅广告 jsBridge.bm.bannerAd(...)
        case "BannerAd": {
            switch (data.action) {
                //广告加载成功
                case "onAdLoad": {
                    break;
                }
                //广告页面展示
                case "onAdShow": {
                    break;
                }
                //广告被点击
                case "onAdClick": {
                    break;
                }
                //广告被关闭
                case "onAdClose": {
                    break;
                }
                //广告出错
                case "onError": {
                    break;
                }
            }
            break;
        }
        //快手短视频 jsBridge.bm.feedVideo(...)
        case "FeedVideo": {
            switch (data.action) {
                //展示普通视频(仅支持 Android)
                case "onShow": {
                    break;
                }
                //展示广告视频(仅支持 Android)
                case "onAdShow": {
                    break;
                }
                //播放普通视频
                case "onStart": {
                    break;
                }
                //播放广告视频
                case "onAdStart": {
                    break;
                }
                //暂停普通视频
                case "onPause": {
                    break;
                }
                //暂停广告视频
                case "onAdPause": {
                    break;
                }
                //恢复普通视频
                case "onResume": {
                    break;
                }
                //恢复广告视频
                case "onAdResume": {
                    break;
                }
                //播完普通视频
                case "onComplete": {
                    break;
                }
                //播完广告视频
                case "onAdComplete": {
                    break;
                }
                //普通视频出错
                case "onVideoError": {
                    break;
                }
                //广告视频出错
                case "onAdVideoError": {
                    break;
                }
            }
            break;
        }
        //横版视频(仅支持 Android) jsBridge.bm.hVideo(...)
        case "HVideo": {
            switch (data.action) {
                //出错
                case "onError": {
                    break;
                }
            }
            break;
        }
        //互动广告(仅支持 Android) jsBridge.bm.hVideo(...)
        case "Interactive": {
            switch (data.action) {
                //出错
                case "onError": {
                    break;
                }
            }
            break;
        }
    }
    //此函数仅用于显示回调参数在本 DEMO 页面上
    showResult({
        event: event,
        data : data
    });
});

//请拉到页面底部查看回调数据信息
$('html,body').animate({ scrollTop: $('#view').offset().top }, 500);

/**
回调参数说明:
event - 事件代码,字符串类型
data  - 事件数据,JSON 对象
{
  action : "事件名称", //如 onShow、onClose 等,与原生 SDK 的各个 Listener 接口里面的方法名称一致
  message: "事件参数"
}
**/

removeListener 移除监听器

//移除监听器,不会再收到回调通知
//在需要时可重新调用 setListener
jsBridge.bm.removeListener();

展示广告

rewardVideoAd 激励视频

unit_id:

//激励视频,event: RewardVideoAd
jsBridge.bm.rewardVideoAd({
  //必须,字符串类型,广告ID
  unit_id : "{{rewardVideoAd.id}}"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

interstitialAd 插屏广告

unit_id:

//插屏广告,event: InterstitialAd
jsBridge.bm.interstitialAd({
  //必须,字符串类型,广告ID
  unit_id: "{{interstitialAd.id}}",
  //必须,数字类型,广告宽度(高度自适应)
  width  : 480
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

bannerAd 横幅广告 - 展示广告

unit_id:

width:

height:

top:

//横幅广告,event: BannerAd
jsBridge.bm.bannerAd({
  //必须,字符串类型,广告ID
  unit_id: "{{bannerAd.id}}",
  //必须,数字类型,期望的广告高度
  width  : {{bannerAd.width}},
  //必须,数字类型,期望的广告宽度
  height : {{bannerAd.height}},
  //可选,数字类型,广告位置上边距,默认 0
  top    : {{bannerAd.top}}
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

bannerAd 横幅广告 - 移除广告

//横幅广告
jsBridge.bm.bannerAd({
  remove: true
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

feedVideo 快手短视频

unit_id:

//快手短视频,event: FeedVideo
jsBridge.bm.feedVideo({
  //广告ID
  unit_id: "{{feedVideo.id}}"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

hVideo 横版视频

unit_id:

//横版视频,仅支持 Android,event: HVideo
jsBridge.bm.hVideo({
  //标题
  title  : "横版视频",
  //主题颜色,light 浅色,dark 深色
  theme  : "light",
  //广告ID
  unit_id: "{{hVideo.id}}"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

hVideo 横版视频 - 深色

//横版视频,仅支持 Android,event: HVideo
jsBridge.bm.hVideo({
  //标题
  title  : "横版视频",
  //主题颜色,light 浅色,dark 深色
  theme  : "dark",
  //广告ID
  unit_id: "hf1"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

interactive 互动广告

unit_id:

//互动广告,仅支持 Android,event: Interactive
jsBridge.bm.interactive({
  //广告ID
  unit_id: "{{interactive.id}}"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

cpa CPA 任务

url:

//CPA 任务,event: 无
jsBridge.bm.cpa({
  //标题
  title: "CPA 任务",
  //主题颜色,light 浅色,dark 深色
  theme: "light",
  //H5 页面链接
  url  : "{{cpa.id}}"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

cpa CPA 任务 - 深色

//CPA 任务
jsBridge.bm.cpa({
  //标题
  title: "CPA 任务",
  //主题颜色,light 浅色,dark 深色
  theme: "dark",
  //H5 页面链接
  url  : "http://dev-qss3-webv.foretellmaster.com/ditch/task?union_id=10000&hideHeader=1"
}, function(succ, data) {
  if (!succ) {
    alert(JSON.stringify(data));
  }
});

用户

setUserId 登录

user_id:

//登录
jsBridge.bm.setUserId({
  user_id : "{{setUserId.id}}"
}, function(succ, data) {
  alert(succ ? "已登录" : JSON.stringify(data));
});

setUserId 退出

//退出
jsBridge.bm.setUserId({
  //用户ID留空则表示退出
  user_id : ""
}, function(succ, data) {
  alert(succ ? "已退出" : JSON.stringify(data));
});

监听回调数据: