gpt4 book ai didi

reactjs - 如何在下一个 js 中从节点模块外部的文件夹中导入模块

转载 作者:行者123 更新时间:2023-12-03 19:23:09 26 4
gpt4 key购买 nike

我一直在努力从 three.js 导入示例模块, 我用过 next.js(服务器端 react 框架)在我的项目中使用 express 的自定义服务器。我的 服务器代码 看起来像这样 -

const express = require('express');
const next = require('next');

const favicon = require('serve-favicon');
var path = require('path');
let fs = require('fs')

const dev = process.env.NODE_ENV !== 'production';
const nextApp = next({ dev });

nextApp.prepare()
.then(() => {

let server = express(), options = {}, PORT = 3000, app = express()

if (dev) {
// DEVELOPMENT ///

// DEVELOPMENT ///
}
else {
// PRODUCTION ///

options = {
...options
}
// PRODUCTION ///
}

server.use(favicon(path.join(__dirname, "/favicon.ico")))


server.get('/', (req, res) => {
const actualPage = '/';
nextApp.render(req, res, actualPage);
});

server.get('*', (req, res) => {
const actualPage = '/not-found';

nextApp.render(req, res, actualPage);
// return handle(req, res)
});


server.listen((PORT), (err) => {
if (err) throw err
console.log('>> Ready on ' + PORT)
})

})

.catch((ex) => {
console.error(ex.stack)
process.exit(1)
})

我基本上运行了一个 npx create-next-app 并配置了一个 custom express server在我的 next.js 项目中进行动态路由,如您在上面的代码中所见。

然后,我使用 three.js 在我的 App.js 文件中导入和渲染的 home 组件中创建了一个场景。我的 home.js 组件看起来像这样 -
import React, { useState, useEffect } from 'react'
import * as THREE from 'three'
import { TrackballControls } from 'three/examples/jsm/controls/TrackballControls'

import "../src/assets/sass/home.scss"

const X = () => {

let parent, renderer, scene, camera, TrackballControls

useEffect(() => {

// renderer
renderer = new THREE.WebGLRenderer()
renderer.setSize( window.innerWidth, window.innerHeight )
document.body.appendChild( renderer.domElement )

// scene
scene = new THREE.Scene()

// camera
camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 100 )
camera.position.set( 20, 20, 20 )

// controls
controls = new TrackballControls( camera )
controls.minDistance = 5
controls.maxDistance = 250
controls.enableDamping = true; // an animation loop is required when either damping or auto-rotation are enabled
controls.dampingFactor = 0.05;

// axes
// scene.add(new THREE.AxisHelper( 20 ))

// geometry
let geometry = new THREE.SphereGeometry( 2, 8, 6, 0, 6.3, 0, 3.1)

// material
let material = new THREE.MeshBasicMaterial({
wireframe: true,
wireframeLinewidth: 1
})

let sphere = new THREE.Mesh( geometry, material )

// parent
parent = new THREE.Object3D()
scene.add( parent )
scene.add( sphere )

function animate() {
requestAnimationFrame( animate )
parent.rotation.z += 0.01
controls.update()
renderer.render( scene, camera )
}

animate()
}

,[])

return <div></div>
}

export default X

现在这是我面临的问题 - 我正在从名为 TrackballControls 的 three.js 中导入一个示例模块,它并不完全位于核心三模块内,而是在它外部的文件夹中,如您从路径中看到的那样 - '三/examples/jsm/controls/TrackballControls.js' .你可以在这里看到更多 - Importing es6 modules separately .但不知何故,它不起作用。它抛出了一个错误,比如

this

我尝试使用简单的 create-react-app 做同样的事情,导入完全有效!所以我知道我的服务器端代码有问题,我假设这是一个与 webpack 相关的问题。但我对 webpack 真的一无所知。有人请帮助我,因为它将不胜感激!

这是我的 next.config.js 如果有帮助,请归档 -
const withSASS = require('@zeit/next-sass')

const { parsed: localEnv } = require('dotenv').config()
const webpack = require('webpack')
// const path = require('path')

function HACK_removeMinimizeOptionFromCssLoaders(config) {
console.warn(
'HACK: Removing `minimize` option from `css-loader` entries in Webpack config',
)
config.module.rules.forEach(rule => {
if (Array.isArray(rule.use)) {
rule.use.forEach(u => {
if (u.loader === 'css-loader' && u.options) {
delete u.options.minimize
}
})
}
})
}

module.exports = withSASS(
{
webpack(config) {
HACK_removeMinimizeOptionFromCssLoaders(config)
config.plugins.push(new webpack.EnvironmentPlugin(localEnv))

return config
}
})

最佳答案

我知道这里没有人看到这个,但如果将来有人遇到这个问题,我会发布我的解决方案。所以这就是我想出来的 -

我在我的问题中没有提到我使用的是名为 next.js 的 SSR(服务器端渲染) react 框架。导入与纯 react 应用程序完美配合。但是在服务器端框架中,与导入相关的东西应该在 useEffect(或 componentDidMount)内完成,以及其余的 threejs 东西。所以我像这样动态导入它 -

let dynamicallyImportPackage = async () => {
let TrackballControls

await import('three/examples/jsm/controls/TrackballControls')
// you can now use the package in here
.then(module => {
TrackballControls = module.TrackballControls
})
.catch(e => console.log(e))

return TrackballControls
}

然后,我像这样在我的 useEffect 中使用它 -
let TrackbackControls = await dynamicallyImportPackage()

// controls
controls = new TrackbackControls(camera, container)
controls.minDistance = 5
controls.maxDistance = 250

Arigato Gosaimasu!

关于reactjs - 如何在下一个 js 中从节点模块外部的文件夹中导入模块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58669052/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com