成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

懶加載-- 端對(duì)端分享功能 --微信釘釘

SoapEye / 1380人閱讀

摘要:技術(shù)細(xì)節(jié)對(duì)以上問(wèn)題解決方案,我采用端對(duì)端懶加載不同平臺(tái)的,分享邏輯統(tǒng)一由后端控制即頁(yè)面里只需要引入一個(gè)腳本??傮w引用方法放置獲取分享信息的入?yún)⑴懦恍枰欠N分享。。。。。。

改造起點(diǎn)

github L6zt

項(xiàng)目前端與后端緊耦合,分享信息 放在jsp里,例如:

前端還要獲取全局變量里的值,初始化分享
2.分享功能沒(méi)有進(jìn)行統(tǒng)一的合并,所以每個(gè)頁(yè)面都需要重寫(xiě)分享邏輯,很low低效的很,而且不利于維護(hù)。
3.每次都需要 引入 釘釘 和 微信 分享的 sdk js 感覺(jué)浪費(fèi)流量,而且 影響頁(yè)面加載速度, 這個(gè)兩個(gè)js都需要同時(shí)引入。

技術(shù)細(xì)節(jié)
對(duì)以上問(wèn)題解決方案,我采用:
端對(duì)端懶加載 不同平臺(tái)的 sdk, 分享邏輯 統(tǒng)一由后端控制 即 頁(yè)面里 只需要引入一個(gè)js腳本。

總體引用方法

// data-ajax 放置獲取分享信息 ajax的入?yún)?//data-exclud 排除 不需要 那種分享

。。。。。。部分代碼
公共函數(shù)

    var noop = function() {};
    var hasOwnP = function(obj, prop) {
        return Object.hasOwnProperty.call(obj, prop);
    };
    var toString = function(obj) {
        return Object.prototype.toString.call(obj);
    };
    var isHardVar = function(obj) {
        var result = toString(obj);
        return result === "[object Object]" || result === "[object Array]";
    }
    var merge = function() {
        var lg = arguments.length;
        var result = {};
        if (lg < 2) {
            return arguments[0]
        };
        for (var i = 0; i < lg; i++) {
            for (var key in arguments[i]) {
                console.log(hasOwnP(arguments[i], key), key);
                if (hasOwnP(arguments[i], key)) {
                    var value = arguments[i][key];
                    result[key] = value;
                }
            }
        }
        return result;
    };

對(duì)異步處理 自己模擬的promise實(shí)現(xiàn)

    var JcPromise = (function() {
        function JcPromise(fn) {
            fn = fn || noop;
            var statusList = ["start", "pending", "succeed", "err"];
            var cbStatus = [0, 1];
            var status = statusList[0];
            var data = null;
            var err = null;
            var that = this;
            var successFn = [];
            var errFn = [];

            function resolve(d) {
                data = d;
                that._changeStatus(2);
            };

            function reject(e) {
                err = e;
                that._changeStatus(3);
            };
            this.getData = function() {
                return data;
            };
            this.getErr = function() {
                return err
            };
            this.getStatus = function() {
                return status
            };
            this._changeStatus = function(idx) {
                switch (status) {
                    case statusList[2]:
                    case statusList[3]:
                        {
                            return false
                        }
                };
                status = statusList[idx];
                if (status === statusList[3]) {
                    setTimeout(function() {
                        that._triggerCatch();
                    }, 0)
                }
                if (status === statusList[2]) {
                    setTimeout(function() {
                        that._triggerThen();
                    }, 0)
                }
            };
            this._pushThenCb = function(cb) {
                successFn.push({
                    status: cbStatus[0],
                    cb: cb
                });
                if (status === statusList[2]) {
                    this._triggerThen();
                }
            };
            this._pushCatchCb = function(cb) {
                errFn.push({
                    status: cbStatus[0],
                    cb: cb
                });
                if (status === statusList[3]) {
                    this._triggerCatch();
                }
            };
            this._triggerThen = function() {
                successFn.map(function(item) {
                    if (item.status === cbStatus[0]) {
                        item.cb(data);
                        item.status = cbStatus[1];
                    }
                })
            };
            this._triggerCatch = function() {
                errFn.map(function(item) {
                    if (item.status === cbStatus[0]) {
                        item.cb(err);
                        item.status = cbStatus[1];
                    }
                })
            };
            this._changeStatus(1);
            this.uuid = uuid++;
            try {
                fn(resolve, reject);
            } catch (e) {
                reject(e)
            }
            return this
        };
        JcPromise.fn = JcPromise.prototype;
        // 返回一個(gè)promise
        JcPromise.fn.then = function(cb) {
            var promiseR = null;
            var promiseJ = null;
            var result = null;
            var that = this;
            var fn = function() {
                setTimeout(function() {
                    try {
                        var data = that.getData();
                        result = cb(data);
                        if (typeof result === "object" && result !== null && result.constructor === JcPromise) {
                            result.then(function(data) {
                                promiseR(data)
                            }).catch(function(e) {
                                promiseJ(e)
                            })
                        } else {
                            promiseR(result)
                        }
                    } catch (e) {
                        promiseJ(e)
                    }
                }, 0);
            };
            this._pushThenCb(fn);
            // 觸發(fā)promise
            return new JcPromise(function(r, j) {
                promiseR = r;
                promiseJ = j;
            });
        };
        // 返回一個(gè)promise
        JcPromise.fn.catch = function(cb) {
            var promiseR = null;
            var promiseJ = null;
            var result = null;
            var that = this;
            var fn = function() {
                setTimeout(function() {
                    try {
                        var data = that.getErr();
                        result = cb(data);
                        if (typeof result === "object" && result !== null && result.constructor === JcPromise) {
                            result.then(function(data) {
                                promiseR(data)
                            }).catch(function(e) {
                                promiseJ(e)
                            })
                        } else {
                            promiseR(result)
                        }
                    } catch (e) {
                        promiseJ(e)
                    }
                }, 0)
            };
            this._pushCatchCb(fn);
            // 觸發(fā)promise
            return new JcPromise(function(r, j) {
                promiseR = r;
                promiseJ = j;
            });
        };
        return JcPromise
    })();

懶加載加載js方法

    function loadScript(src) {
        return new JcPromise(function(r, j) {
            var el = document.createElement("script");
            el.onload = function() {
                r(el);
            };
            el.onerror = function() {
                j();
            };
            el.src = src;
            document.body.appendChild(el);
        });
    };

判斷 是釘

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/108880.html

相關(guān)文章

  • Yoshua Bengio最新演講:Attention 讓深度學(xué)習(xí)取得巨大成功

    摘要:深度學(xué)習(xí)理論在機(jī)器翻譯和字幕生成上取得了巨大的成功。在語(yǔ)音識(shí)別和視頻,特別是如果我們使用深度學(xué)習(xí)理論來(lái)捕捉多樣的時(shí)標(biāo)時(shí),會(huì)很有用。深度學(xué)習(xí)理論可用于解決長(zhǎng)期的依存問(wèn)題,讓一些狀態(tài)持續(xù)任意長(zhǎng)時(shí)間。 Yoshua Bengio,電腦科學(xué)家,畢業(yè)于麥吉爾大學(xué),在MIT和AT&T貝爾實(shí)驗(yàn)室做過(guò)博士后研究員,自1993年之后就在蒙特利爾大學(xué)任教,與 Yann LeCun、 Geoffrey Hinto...

    LMou 評(píng)論0 收藏0
  • 吳恩達(dá) NIPS 2016唯一的中文版PPT

    摘要:今日,在第屆神經(jīng)信息處理系統(tǒng)大會(huì)中,百度首席科學(xué)家吳恩達(dá)教授發(fā)表演講利用深度學(xué)習(xí)開(kāi)發(fā)人工智能應(yīng)用的基本要點(diǎn)。為了方便讀者學(xué)習(xí)和收藏,雷鋒網(wǎng)特地把吳恩達(dá)教授的做為中文版。吳恩達(dá)先講述了常見(jiàn)的深度學(xué)習(xí)模型,然后再著分析端到端學(xué)習(xí)的具體應(yīng)用。 今日,在第 30 屆神經(jīng)信息處理系統(tǒng)大會(huì)(NIPS 2016)中,百度首席科學(xué)家吳恩達(dá)教授發(fā)表演講:《利用深度學(xué)習(xí)開(kāi)發(fā)人工智能應(yīng)用的基本要點(diǎn)(Nuts an...

    yunhao 評(píng)論0 收藏0
  • 選型云ERP中五個(gè)不能忽視的問(wèn)題

    摘要:企業(yè)在選擇云系統(tǒng)時(shí),尤其如此。云系統(tǒng)中的每個(gè)因素都與公司成長(zhǎng)模式有關(guān)。成本蠕變成本蠕變或許是最普遍也是最容易被負(fù)責(zé)人忽略的,對(duì)云系統(tǒng)的產(chǎn)生的影響也是更為負(fù)面的。如果你選擇的云服務(wù)組合是正確的,云系統(tǒng)的擴(kuò)張就應(yīng)該是順其自然的。 一、在選擇過(guò)程中忽略重要的云屬性企業(yè)在購(gòu)買(mǎi)整合系統(tǒng)時(shí)要面對(duì)一系列的挑戰(zhàn)性,除了要理解公司行為方式和原因以外,還需要有考慮到其他因素。如果忽略了某個(gè)流程或要求,那么在這個(gè)...

    venmos 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<