码迷,mamicode.com
首页 > Web开发 > 详细

webview页面和壳通信的库(精简版)

时间:2015-06-25 17:06:42      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:

// PG精简版
(function() {
    var PG = {
            iosBridge: null,
            callbackId: 0,
            callbacks: [],
            commandQueue: [],
            commandQueueFlushing: false
        },
        ua = navigator.userAgent,
        isIOS = (ua.indexOf("iPhone") > -1 || ua.indexOf("iPad") > -1 || ua.indexOf("iPod") > -1) ? true : false;
    PG.getAndClearQueuedCommands = function () {
        var commandQueue_json = JSON.stringify(PG.commandQueue);
        PG.commandQueue = [];
        return commandQueue_json;
    };

    PG.exec = function(method, callback, args) {
        var callbackId = ‘‘;
        if (typeof(callback) == "undefined") {
            callback = null;
        }
        if (typeof(args) == "undefined") {
            args = {};
        }


        if (callback && typeof(callback) == ‘function‘) {
            callbackId = method + PG.callbackId++;
            PG.callbacks[callbackId] = callback;
        }

        var obj = {
            Method: method,
            CallbackId: callbackId,
            Args: args
        };

        if (isIOS) {
            if (PG.iosBridge == null) {
                PG.iosBridge = document.createElement("iframe");
                PG.iosBridge.setAttribute("style", "display:none;");
                PG.iosBridge.setAttribute("height", "0px");
                PG.iosBridge.setAttribute("width", "0px");
                PG.iosBridge.setAttribute("frameborder", "0");
                document.documentElement.appendChild(PG.iosBridge);
            }

            PG.commandQueue.push(JSON.stringify(obj));
            if (!PG.commandQueueFlushing) {
                PG.iosBridge.src = ‘pg://ready‘;
            }
            
            
        } else if (window.comjs) {
            // android
            window.comjs.notify(‘pg://‘ + encodeURIComponent(JSON.stringify(obj)));
        } else {
            console.log("非ios或android平台,不合适吧");
        }


    };

    PG.callback = function(callbackId, args) {
        if (PG.callbacks[callbackId]) {
            try {
                var temp = decodeURIComponent(args),
                    obj = JSON.parse(temp);

                PG.callbacks[callbackId](obj);

            } catch (e) {
                console.log("Error in success callback: " + callbackId + " = " + e);
            }

            delete PG.callbacks[callbackId];

        }
    };

    
        
    if (typeof(window) === "object" && typeof(window.document) === "object") {
        window.PG = PG;
    }
        

    

})();

 

webview页面和壳通信的库(精简版)

标签:

原文地址:http://www.cnblogs.com/samwu/p/4600068.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!