お世話になります。
相変わらず、exprsssへのリクエスト周りで苦戦しています。
参考のように、postmanでは、expressにリクエストできるのですが、これをreactでやろうとすると、なぜかエラーが出るor出なくても、Cannot read property 'name' of undefined と言われています。
- コンソールには、getした情報が出ているが、ブラウザには、Cannot read property 'name' of undefinedと出る
- ブラウザをリフレッシュすると、この場合はコンソールにエラ〜メッセージが出力される。
という症状に苛まれています。
自分で試したことは、
- HOOKを試す
- fetchを試す
- axiosを試す
- axiosには、corsが必要なことがわかり、それを組み合わせる
- それでも動かない
調べていっても、どれも微妙に書き方だったりアプローチが違っていて、そろそろわからなくなってきています....
どこで僕がミスっているのかが、わからなくなっています・
react, express, cors, axiosを用いて、"知的好奇心"の文字列だけ引っ張るやり方を知りたいです。
json
1[ 2 { 3 "trait_id": "big5_openness", 4 "name": "知的好奇心", 5 "percentile": 0.8132488073788707 6 }, 7 { 8 "trait_id": "big5_conscientiousness", 9 "name": "誠実性", 10 "percentile": 0.7249905110313153 11 }, 12 { 13 "trait_id": "big5_extraversion", 14 "name": "外向性", 15 "percentile": 0.994361109700101 16 }, 17 { 18 "trait_id": "big5_agreeableness", 19 "name": "協調性", 20 "percentile": 0.9611599687822684 21 }, 22 { 23 "trait_id": "big5_neuroticism", 24 "name": "感情起伏", 25 "percentile": 0.39308810113669834 26 } 27]
Big5.js(React)
javascript
1import React from 'react'; 2import { 3 CardColumns 4} from 'react-bootstrap'; 5import axios from 'axios'; 6 7import Big5List from '../components/Big5List.js'; 8 9class Big5sRio extends React.Component { 10 11 constructor(props){ 12 super(props); 13 this.state = { 14 big5s:[] 15 }; 16 this.loadAjax(); 17 } 18 19 async loadAjax(){ 20 const res = (await axios.get('http://localhost:5000/big5db/all')) 21 console.log(res) 22 23 this.setState({ 24 big5s: res 25 }) 26 } 27 28 async loadAjax2() { 29 try { 30 const res = await fetch('http://localhost:5000/big5db/all'); 31 const json = await res.json(); 32 console.log(json) 33 this.setState({ 34 big5s: json, 35 }); 36 } 37 catch (err) { 38 console.error(err); 39 } 40 } 41 42 render(){ 43 const big5ss = this.state.big5s[0].name; 44 return( 45 <div> 46 {big5ss && big5ss} 47 </div> 48 ) 49 } 50 51} 52 53export default Big5sRio; 54
BIg5db_controllers.js(該当箇所のみ)
javascpirt
1const getBig5all = async (req, res, next) => { 2 3 let big5s; 4 let big5ss; 5 6 try { 7 await client.connect({ useUnifiedTopology: true }); 8 9 var db = client.db("test_db"); 10 var collection = db.collection("Big5"); 11 12 big5s = await collection.find({}).toArray(); 13 big5rio = big5s[1].personality.map(({trait_id,name,percentile})=>({trait_id,name,percentile})) 14 15 } catch (error) { 16 return res.json({message: 'Could not retrieve products.'}); 17 }; 18 client.close(); 19 20 res.json(big5rio) 21}
app.js(cors追加済み)
javascpirt
1var createError = require('http-errors'); 2var express = require('express'); 3var path = require('path'); 4var cookieParser = require('cookie-parser'); 5var logger = require('morgan'); 6var cors = require("cors"); 7 8var indexRouter = require('./routes/index'); 9var usersRouter = require('./routes/users'); 10var big5db = require('./routes/big5db'); 11var twitter = require('./routes/twitter'); 12var cognition = require('./routes/cognition'); 13 14var app = express(); 15 16app.use(cors()); 17 18/* 19//Reactからのリクエストを受け取るのに必要 20const allowCrossDomain = function(req, res, next) { 21 res.header('Access-Control-Allow-Origin', req.headers.origin) 22 res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE') 23 res.header( 24 'Access-Control-Allow-Headers', 25 'Content-Type, Authorization, access_token' 26 ) 27 28 // intercept OPTIONS method 29 if ('OPTIONS' === req.method) { 30 res.send(200) 31 } else { 32 next() 33 } 34} 35app.use(allowCrossDomain) 36*/ 37 38 39// view engine setup 40app.set('views', path.join(__dirname, 'views')); 41app.set('view engine', 'ejs'); 42 43app.use(logger('dev')); 44app.use(express.json()); 45app.use(express.urlencoded({ extended: false })); 46app.use(cookieParser()); 47app.use(express.static(path.join(__dirname, 'public'))); 48 49app.use('/', indexRouter); 50app.use('/users', usersRouter); 51app.use('/twitter', twitter); 52app.use('/big5db', big5db); 53app.use('/cognition', cognition); 54 55 56// catch 404 and forward to error handler 57app.use(function(req, res, next) { 58 next(createError(404)); 59}); 60 61// error handler 62app.use(function(err, req, res, next) { 63 // set locals, only providing error in development 64 res.locals.message = err.message; 65 res.locals.error = req.app.get('env') === 'development' ? err : {}; 66 67 // render the error page 68 res.status(err.status || 500); 69 res.render('error'); 70}); 71 72module.exports = app; 73
関係しているファイルは、おそらくこの辺りだと思います。
必要な情報をかけていない場合、申し付けください。
あなたの回答
tips
プレビュー