• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天地之靈

            pomelo實(shí)戰(zhàn)填坑記 前端坑之Buffer is not defined

            實(shí)戰(zhàn)pomelo過程中,自己重新進(jìn)行component build之后發(fā)現(xiàn)輸出的網(wǎng)頁在瀏覽器端報(bào)錯(cuò):

            Uncaught ReferenceError: Buffer is not defined

            閱讀代碼后分析如下:
            模塊 pomelo-protocol 的代碼,試圖兼容node.js與瀏覽器端,其區(qū)分方法是 判斷module是否是一個(gè)object。
            ('object' === typeof module ? module.exports : (this.Protocol = {}),'object' === typeof module ? Buffer : Uint8Array, this);

            在node.js中,module是一個(gè)object,而在瀏覽器端,早期版本的component實(shí)現(xiàn) 把module的函數(shù)自身作為最后一個(gè)參數(shù)(命名為module)
              if (!module.exports) {
                module.exports = {};
                module.client = module.component = true;
                module.call(this, module.exports, require.relative(resolved), module);
              }

            所以typeof(module)得到的是一個(gè)function。

            但是隨著component的更新,component改變了這個(gè)特性:
              if (!module._resolving && !module.exports) {
                var mod = {};
                mod.exports = {};
                mod.client = mod.component = true;
                module._resolving = true;
                module.call(this, mod.exports, require.relative(resolved), mod);
                delete module._resolving;
                module.exports = mod.exports;
              }

            可以看到最后一個(gè)參數(shù)現(xiàn)在是一個(gè)新創(chuàng)建出來的Object,所以現(xiàn)在在瀏覽器上,pomelo-protocol也認(rèn)為現(xiàn)在正在node.js環(huán)境中,于是就報(bào)錯(cuò)了。

            一個(gè)臨時(shí)的workaround辦法是,在require("promelo-protocol")之前,先準(zhǔn)備好Buffer,代碼如下:

            window.Buffer = Uint8Array;
            var protocol = require('pomelo-protocol');
            window.Protocol = protocol;
            delete window.Buffer;
            這樣問題暫時(shí)消除了。當(dāng)然,最靠譜的辦法還是在pomelo-protocol中修改識(shí)別環(huán)境的辦法。稍后我會(huì)向pomelo提交pull-request幫助解決這一問題。

            posted on 2013-11-10 11:17 天地之靈 閱讀(7845) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(3)

            隨筆檔案

            文章檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            日韩中文久久| 久久久久国色AV免费看图片 | 亚洲综合精品香蕉久久网97| 久久丫精品国产亚洲av不卡| 久久免费视频1| 天天综合久久一二三区| 狠狠精品久久久无码中文字幕| 久久婷婷人人澡人人爽人人爱 | 欧美久久天天综合香蕉伊| 亚洲国产精品无码久久青草| 久久久国产亚洲精品| 久久99亚洲网美利坚合众国| 久久久噜噜噜久久中文字幕色伊伊| 伊人久久大香线蕉AV一区二区| 无遮挡粉嫩小泬久久久久久久| 久久精品国产亚洲精品2020| 91精品婷婷国产综合久久| 国产精品免费久久久久影院| 久久夜色精品国产www| 伊人久久成人成综合网222| 亚洲中文字幕无码久久精品1 | 9191精品国产免费久久| 一本一道久久a久久精品综合| 国产精品久久久久久久久久免费| 欧美激情精品久久久久久久九九九 | 国产精品乱码久久久久久软件| 九九精品99久久久香蕉| 亚洲国产成人精品无码久久久久久综合 | 久久亚洲AV成人无码软件| 久久久精品人妻一区二区三区四 | 香蕉久久夜色精品国产2020| 97久久国产亚洲精品超碰热| 狠狠色婷婷久久一区二区| 久久人人爽人人爽人人片AV麻豆 | 久久精品亚洲精品国产色婷| 伊色综合久久之综合久久| 久久久久噜噜噜亚洲熟女综合| 精品多毛少妇人妻AV免费久久| 国产精品内射久久久久欢欢| 亚洲精品乱码久久久久久中文字幕 | 久久久久国产|