搜尋

首頁  >  問答  >  主體

使用vite/rollup.js來擴充Node.js的os模組

<p>我正在處理一個使用<code>opensea-js</code>套件的Vite專案。這個套件依賴<code>xhr2-cookies</code>,它匯入了<code>os</code>、<code>http</code>、<code>https</code>http</code>、<code>https</code>和其他其他一些內部的node模組。 </p> <p>當我嘗試呼叫任何opensea方法時,出現了以下錯誤:</p> <pre class="brush:php;toolbar:false;">Uncaught (in promise) TypeError: os.type不是一個函數 XMLHttpRequest2 xml-http-request.ts:102 prepareRequest httpprovider.js:61 sendAsync httpprovider.js:116 node_modules opensea-js.js:24209</pre> <p>追蹤這個錯誤,發現它來自建構用戶代理字串。 </p> <p>我嘗試安裝<code>rollup-plugin-polyfill-node</code>並將其添加到<code>vite.config.js</code>中,但仍然出現相同的錯誤:< ;/p> <pre class="brush:php;toolbar:false;">import path 從 'path' import vue from '@vitejs/plugin-vue' import nodePolyfills from 'rollup-plugin-polyfill-node' import { defineConfig } from 'vite' // https://vitejs.dev/config/ export default defineConfig({ plugins: [vue()], resolve: { alias: { '@': path.resolve(__dirname, 'src'), }, }, server: { port: 8080, }, define: { 'process.env': {}, }, build: { rollupOptions: { plugins: [ nodePolyfills(), ], }, }, })</pre> <p>我還嘗試使用<code>patch-package</code>手動修復文件,這樣可以解決<code>os</code>錯誤,但在嘗試發送請求時失敗(因為它使用需要進行polyfill的<code>http</code>/<code>https</code>模組)。 </p>
P粉176151589P粉176151589543 天前579

全部回覆(2)我來回復

  • P粉863295057

    P粉8632950572023-08-25 12:11:28

    我使用了 rollup-plugin-polyfill-node 來解決這個問題。

    import nodePolyfills from 'rollup-plugin-polyfill-node';
    rollup({
      entry: 'main.js',
      plugins: [
        nodePolyfills( /* options */ )
      ]
    })

    這是基於Fabiano的答案的更完整的解決方案:

    // yarn add --dev @esbuild-plugins/node-globals-polyfill
    import { NodeGlobalsPolyfillPlugin } from '@esbuild-plugins/node-globals-polyfill'
    // yarn add --dev @esbuild-plugins/node-modules-polyfill
    import { NodeModulesPolyfillPlugin } from '@esbuild-plugins/node-modules-polyfill'
    import nodePolyfills from 'rollup-plugin-polyfill-node';
    
    export default {
            optimizeDeps: {
                esbuildOptions: {
                    // Node.js global to browser globalThis
                    define: {
                        global: 'globalThis'
                    },
                    // Enable esbuild polyfill plugins
                    plugins: [
                        NodeGlobalsPolyfillPlugin({
                            process: true,
                            buffer: true
                        }),
                        NodeModulesPolyfillPlugin()
                    ]
                }
            },
            build: {
                rollupOptions: {
                    plugins: [
                        // Enable rollup polyfills plugin
                        // used during production bundling
                        nodePolyfills()
                    ]
                }
            }
    }

    回覆
    0
  • P粉720716934

    P粉7207169342023-08-25 00:11:17

    在我的專案中,我使用了以下配置來解決問題。我在一篇簡短的文章中描述了解決方案。

    // yarn add --dev @esbuild-plugins/node-globals-polyfill
    import { NodeGlobalsPolyfillPlugin } from '@esbuild-plugins/node-globals-polyfill'
    // yarn add --dev @esbuild-plugins/node-modules-polyfill
    import { NodeModulesPolyfillPlugin } from '@esbuild-plugins/node-modules-polyfill'
    // You don't need to add this to deps, it's included by @esbuild-plugins/node-modules-polyfill
    import rollupNodePolyFill from 'rollup-plugin-node-polyfills'
    
    export default {
            resolve: {
                alias: {
                    // This Rollup aliases are extracted from @esbuild-plugins/node-modules-polyfill, 
                    // see https://github.com/remorses/esbuild-plugins/blob/master/node-modules-polyfill/src/polyfills.ts
                    // process and buffer are excluded because already managed
                    // by node-globals-polyfill
                    util: 'rollup-plugin-node-polyfills/polyfills/util',
                    sys: 'util',
                    events: 'rollup-plugin-node-polyfills/polyfills/events',
                    stream: 'rollup-plugin-node-polyfills/polyfills/stream',
                    path: 'rollup-plugin-node-polyfills/polyfills/path',
                    querystring: 'rollup-plugin-node-polyfills/polyfills/qs',
                    punycode: 'rollup-plugin-node-polyfills/polyfills/punycode',
                    url: 'rollup-plugin-node-polyfills/polyfills/url',
                    string_decoder:
                        'rollup-plugin-node-polyfills/polyfills/string-decoder',
                    http: 'rollup-plugin-node-polyfills/polyfills/http',
                    https: 'rollup-plugin-node-polyfills/polyfills/http',
                    os: 'rollup-plugin-node-polyfills/polyfills/os',
                    assert: 'rollup-plugin-node-polyfills/polyfills/assert',
                    constants: 'rollup-plugin-node-polyfills/polyfills/constants',
                    _stream_duplex:
                        'rollup-plugin-node-polyfills/polyfills/readable-stream/duplex',
                    _stream_passthrough:
                        'rollup-plugin-node-polyfills/polyfills/readable-stream/passthrough',
                    _stream_readable:
                        'rollup-plugin-node-polyfills/polyfills/readable-stream/readable',
                    _stream_writable:
                        'rollup-plugin-node-polyfills/polyfills/readable-stream/writable',
                    _stream_transform:
                        'rollup-plugin-node-polyfills/polyfills/readable-stream/transform',
                    timers: 'rollup-plugin-node-polyfills/polyfills/timers',
                    console: 'rollup-plugin-node-polyfills/polyfills/console',
                    vm: 'rollup-plugin-node-polyfills/polyfills/vm',
                    zlib: 'rollup-plugin-node-polyfills/polyfills/zlib',
                    tty: 'rollup-plugin-node-polyfills/polyfills/tty',
                    domain: 'rollup-plugin-node-polyfills/polyfills/domain'
                }
            },
            optimizeDeps: {
                esbuildOptions: {
                    // Node.js global to browser globalThis
                    define: {
                        global: 'globalThis'
                    },
                    // Enable esbuild polyfill plugins
                    plugins: [
                        NodeGlobalsPolyfillPlugin({
                            process: true,
                            buffer: true
                        }),
                        NodeModulesPolyfillPlugin()
                    ]
                }
            },
            build: {
                rollupOptions: {
                    plugins: [
                        // Enable rollup polyfills plugin
                        // used during production bundling
                        rollupNodePolyFill()
                    ]
                }
            }
    }

    回覆
    0
  • 取消回覆