質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

Q&A

解決済

2回答

1825閲覧

exportsしたモジュールの戻り値が取得できない。Express.jsでGET中に呼び出した非同期処理の関数

moimoi_sushi

総合スコア26

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

0グッド

0クリップ

投稿2020/05/17 05:43

前提・実現したいこと

Cherrio-httpcliをExpress.js経由で叩き結果を返したいです。
DcukDuckGoと呼ばれる検索エンジンの検索結果をスクレイピングしたものをクライアントへresしたいです。

発生している問題・エラーメッセージ

以下のコードでduckGo関数をasync/awaitを用いつつ呼び出しているのですが結果が返ってきません。

**main.js** const express = require('express'), app = express(), duck = require('./public/js/duckduck'); app.set("port", process.env.PORT || 3000) app.get('/', (req, res) => { (async() => { const result = await duck.duckGo("テスト") //undefinedの結果。ここで本来はduckduckGoの検索結果が返ってきて欲しい console.log(result); res.send(result); return; })().catch(console.log("done")) }) app.listen(app.get("port"), ()=>{ console.log(`Server リスナ: ${app.get("port")}監視中`); })
**duckduck.js** const client = require('cheerio-httpcli'), $ = require('jquery'),  targetURL = 'http://duckduckgo.com/html'; async function duckGo (keyword) { await client.fetch(targetURL, { q: keyword }) .then((result) => { let test = []; result.$('#links').each(function (idx, elm) { // ここで結果が返ってきていることは確認済み test.push(result.$(this).find('h2').text()); }); return test; }) .catch((err) => { console.log(err); }) } exports.duckGo = duckGo

試したこと

duckduck.jsの方で別途、簡易的な関数をつくりreturnさせたところGET側で戻り値を取得できました。

GET側の同期処理も順番通りうまくいっているようですが結果がなぜか返ってこず、参考になりそうな記事を英語でも探してたのですが解決できず質問するに至りました。

補足情報(FW/ツールのバージョンなど)

**package.jsonの中身** { "name": "test", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "start": "nodemon main.js" }, "keywords": [], "author": "", "license": "ISC", "dependencies": { "async": "^3.2.0", "cheerio-httpcli": "^0.7.4", "express": "^4.17.1", "jquery": "^3.5.1", "nodemon": "^2.0.4" } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

const result = await duck.duckGo("テスト")

duckduck.js について、await(待機)するけど、
暗黙の resolver() 実行となっています(return undefined:)。
await の左辺に渡される Promise を返却してください。

javascript

1async function duckGo (keyword) { 2 // await client.fetch(targetURL, { q: keyword }) 3 return await client.fetch(targetURL, { q: keyword }) 4 5 /* omitted */ 6 7 // return Promiseでないので、return undefined; と同じ 8} 9exports.duckGo = duckGo

投稿2020/05/17 11:10

AkitoshiManabe

総合スコア5434

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

moimoi_sushi

2020/05/17 15:33

感謝感激です。無事、戻り値を取得できました。 thenで返した値あとにfetchでも返すことで値がGET側へ渡されるのに、fetch側でreturn( resolve() )をしていないためにundefinedが返されていた、ということでしょうか。 async/await、また一からやり直しですね。。
guest

0

result の結果を取得する前に配列 test を空の状態で返しているのではないでしょうか。

Promiseチェーンをつなげて、test.push した後に then returnすると良いのでは。

(ぱっと見の印象で書いたため、間違っていたらすみません)

投稿2020/05/17 09:28

編集2020/05/17 10:04
apprentice

総合スコア67

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

moimoi_sushi

2020/05/17 15:34

ヒントとなるコメントありがとうございます。無事、returnをfetch関数のところに加えることで値を渡すことができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問