Bid Viewability - Ad Server Independent
Overview
This optional module will trigger a BID_VIEWABLE event which can be consumed by Analytics adapters. In addition, the winning bidder can implement an onBidViewable
method to capture this event.
Notes:
- The module works with any adserver, or with no ad server at all.
- Publishers using GAM/GPT might consider using the Bid Viewable Event - GAM module
- Requires the site to polyfill the IntersectionObserver API (v1) to find when a bid is viewable. This implementation assumes that the publisher and the bidder are acting in good faith, and does not attempt to detect any bad behavior from either party. We assume that the ad is rendered into the element it has been told to render into, and is not hidden or obfuscated at any time.
- This event is fired when an impression becomes viewable, according to IAB’s viewability guidelines
- When a rendered PBJS bid is determined to be viewable this module will trigger a BID_VIEWABLE event, which can be consumed by the winning bidder and analytics adapters
- The module works with Banner creatives, with additional support to come.
Known Issues
This feature is not intended to be a perfect measure of viewability. It is however intended to be a reasonable approximation of a bids viewability for creative types that are supported.
- Only supports Banner creatives
- Only works on browsers that support or on sites that have polyfilled the IntersectionObserver API
- Results can only be trusted if both the publisher and winning bidder are assumed to be acting in good faith.
Note that there are other viewability modules in Prebid.js:
Configuration
Field |
Scope |
Type |
Description |
bidViewabilityIO |
Required |
Object |
Configuration object for viewability tracking for supported media types (IO stands for IntersectionObserver) |
bidViewabilityIO.enabled |
Required |
Boolean |
when set to true, the module will emit BID_VIEWABLE when applicable. Default: false |
Example of setting module config
pbjs.setConfig({
bidViewabilityIO: {
enabled: true,
}
});
Example of consuming BID_VIEWABLE event
pbjs.onEvent("bidViewable", function(bid){
console.log("got bid details in bidViewable event", bid);
});