移動網頁廣告引入mraid.js使用指南

来源:https://www.cnblogs.com/beileixinqing/archive/2019/02/26/10440201.html
-Advertisement-
Play Games

在網上找mraid相關資料,相對比較少,大多都是API介紹,概念介紹等,沒有一份詳細的移動端網頁廣告使用教程,經過自己兩天的摸索,完成了開發的移動端網頁版的廣告加入mraid功能。 背景: 我開發了移動端網頁展示的廣告,由於產品的要求,要實現廣告中的視頻在用戶看到的時候才會繼續播放,不看的時候不會播 ...


在網上找mraid相關資料,相對比較少,大多都是API介紹,概念介紹等,沒有一份詳細的移動端網頁廣告使用教程,經過自己兩天的摸索,完成了開發的移動端網頁版的廣告加入mraid功能。

背景:

我開發了移動端網頁展示的廣告,由於產品的要求,要實現廣告中的視頻在用戶看到的時候才會繼續播放,不看的時候不會播放,而預設設置的video 的autoplay自動播放會在用戶打開的情況下,即使看不到也是種播著,影響了用戶看到的廣告效果,即可能會降低點擊率和轉化率。

而mraid具有天然的優勢,mraid可以識別用戶是否在看著廣告,可以識別用戶的點擊跳轉,可以出現關閉按鈕點擊關閉,可以縮放廣告等,推薦mriad中文版教程:

https://github.com/graypants/mraid_cn/blob/master/mraid_cn.md

開始

1、在網頁中首先引入mraid.js【直接引入即可,不需要在本地放mraid.js,頁面在支持mraid的app中會自動註入】

<script src="mraid.js"></script>

2、在PC端開發完成之後,不方便測試mraid效果,推薦這個網站:http://webtester.mraid.org/

 

可以線上設置廣告位的寬高,粘貼代碼,render之後查看效果。

3、mraid實現視頻用戶瀏覽時播放,並且點擊下載mraid跳轉完整代碼:

let v = document.getElementsByTagName("video")[0];//獲取video元素
let ad_pic = document.getElementsByClassName("ad_pic")[0];//視頻暫停時的圖片
// 視頻播放
function videoPlay() {
    let videoIsPlay = v.play();
    if (videoIsPlay !== undefined) {
        videoIsPlay.then(() => {//通過非同步的方式避免報錯
            ad_pic.style.display = "none";
        }).catch((err) => {
            console.log(err);
            ad_pic.style.display = "none";//預設暫停時的圖片隱藏
            //視頻元素可以選擇靜音後再播放,提示用戶打開聲音
            v.muted = true;
            v.play();
        });
    }
}
//圖片點擊播放
function cardClick(event) {
    "use strict";
    ad_pic.addEventListener(event, function () {
        videoPlay();
        v.className = '';
    }, true);
}
function adPic() {
    cardClick('tap');
    cardClick('click');
}
// mraid判斷
function mraidPlay() {
    "use strict";
    if (mraid.getState() === 'loading') {
        mraid.addEventListener('ready', onSdkReady);
    } else {
        onSdkReady();
    }
    function onSdkReady() {
        if (mraid.isViewable()) {
            videoPlay();
        } else {
            mraid.addEventListener('viewableChange', function (viewable) {
                if (viewable) {
                    mraid.removeEventListener('viewableChange');
                    videoPlay();
                }
            });
        }
    }
}

在使用video.play()方法的時候,有時候會出現報錯:

Uncaught (in promise) DOMException

有一篇文章寫的比較好:推薦一下

4、mraid代碼實現的流程:

先判斷mraid狀態是否為loading,如果為loading要給mraid註冊ready事件,在ready事件中進行相應mraid代碼執行,比如判斷用戶是否在瀏覽廣告,如果不是loading狀態,則說明是ready狀態,直接執行mraid操作的代碼。

mraid.js,所有事件發生都要在ready之後,mraid.open也需要ready之後,只要引入了mraid.js,就可以識別mraid對應的方法存在,但是事件的執行要在ready事件之後。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先參照官方文檔進行搭建Mac下的環境 ,然後就會遇到以下問題: 1.在下載了Flutter 之後,執行Flutter doctor之後,報錯: Could not resolve URL "https://pub.flutter-io.cn". Could not resolve URL "htt ...
  • ContentProvider ContentProvider 在android中的作用是對外共用數據,也就是說你可以通過ContentProvider把應用中的數據共用給其他應用訪問,其他應用可以通過ContentProvider 對你應用中的數據進行添刪改查。ContentProvider的就是 ...
  • 1、Activity的生命周期 1.1、典型情況下的生命周期 在有用戶參與的情況下,Activity所經過的生命周期的改變。 Activity會經歷如下生命周期: onCreate onRestart onStart onResume onPause onStop onDestroy 1.2、異常情 ...
  • VirtualApk引入步驟: 一、宿主應用引入VirtualApk 1、在項目的build.gradle文件中加入依賴: dependencies { classpath 'com.didi.virtualapk:gradle:0.9.8.6' } 完整的gradle文件如下: // Top le ...
  • 因為是v-for 迴圈 出來的,:key = "index" 會出現問題,所以,需要把:key="XXX"換成其他屬性就好了。 鏈接參考: https://segmentfault.com/q/1010000008276837 https://cn.vuejs.org/v2/guide/list.h ...
  • 1. 元素類名更改 2. mui下的fonts文件夾中添加mui-icons-extra.ttf文件 3. mui下的css文件中添加icons-extra.css文件 4. main.js中導入import './lib/mui/css/icons-extra.css' ...
  • 模塊化 目前比較流行的 JS 模塊化方案有 CommonJS、AMD、CMD 以及 ES6 Module,還有個 UMD 方案。 CommonJS CommonJS 是伺服器端的模塊化方案,nodeJs 就採用了這種方案。在 CommonJS 規範中,一個文件即一個模塊,用 和`exports re ...
  • 一個完整的JavaScript 實現由3部分組成: ECMACcript ECMAScript 規定了這門語言的下列組成部分: 語法 類型 語句 關鍵字、保留字 操作符 對象為什麼要使用DOM? Document Object Model 文檔對象模型,是文檔,是對瀏覽器內的內容進行操作。 DOM並 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...