🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

import

自身のプラットフォーム・プログラム・データセットに対して、外部ソースを取り込むプロセスをimportと呼びます。

JavaScript

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

1回答

1291閲覧

.jsファイルに書かれた自作関数群を別の.jsファイルにエクスポートする方法を教えて下さい。

tetatetu

総合スコア26

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

import

自身のプラットフォーム・プログラム・データセットに対して、外部ソースを取り込むプロセスをimportと呼びます。

JavaScript

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/03/29 11:46

編集2021/03/29 12:00

以前の質問にて、一つのJavaScriptのソースコードに散らばっている関数やクラスを複数のファイルに分けて管理する方法として、モジュール機能のimport/export文の利用を検討しました。
しかし、モジュールに指定したソースファイルに書かれた変数やオブジェクトは全てローカル変数として扱われてしまい、グローバル変数を使うことが出来ない、というJavaScriptのモジュール機能の仕様がアダとなって、利用を断念することにしました。(目的のプログラムがp5.jsライブラリーのグローバルオブジェクトを使うものだったため)

そこで、モジュール機能のimport/export文以外で、JavaScriptのソースコードに書かれた関数やオブジェクトを別々に管理する方法を探しています。しかし、調べても基本的にはimport/exportを使う方法ばかりで、見つけることができません。

何か良い方法はないでしょうか?
もし、import/exportを使ってでも出来る裏技があれば、それでも結構です。

ご回答頂けると幸いです。

追記

こちらにあるmaisumakun様のご回答を試したところ、私の自作関数/自作オブジェクトに限ってはwindowオブジェクトと結び付けてからexportすることで、globalに出現させることに成功しました。しかし、p5.jsに用意されている既定のグローバルオブジェクト群やグローバル変数群を全てwindowオブジェクトと結びつけてexportするのは大変そうなので、(使うオブジェクトが少ないならまだしも)いつでも通用する最適解ではないかもしれません。

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

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

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

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

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

guest

回答1

0

同じJavaScriptでも全部<script>で読み込んで使う昔ながらの方法の時代と
webpackなどでビルドが当たり前の時代では使い方・考え方が何もかも違う。
一番重要な知識が抜けたまま古い情報と新しすぎる情報を見てJSを使おうとしてるので壮大に間違えてる。

いにしえのJS→webpackなどでビルド=トランスパイル時代→module。
他の人は何年もかけて順番に経験を積んでいる。JSのグローバルがどういうことかなんて早い段階で身につけること。
グローバルなp5はおそらくwindow.p5なのでこれで使えるはず。
module使うのはまだ時期尚早。いずれ当たり前になるとしても初心者が使うには情報が足りない。
今はまだwebpackを使う段階。

投稿2021/03/29 12:26

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

tetatetu

2021/03/29 14:50

ご回答ありがとうございます。頂いたご回答の意味ですが、 ・単純に複数のscriptタグを作り、メインのjsファイルと関数群を書いたjsファイルをsrcにセットする ・webpackを使う の2つの方法がある、ということで間違いないでしょうか?
tetatetu

2021/03/29 15:02 編集

一つ目については、灯台下暗しでした。 c++などでヘッダファイルや他のcppファイルから関数を取り込むのと似たノリで、 htmlファイルを介さずに.jsファイル同士の間で関数のやり取りをできる方がプログラムとして自然なのかと思い、import/exportを試そうとしたのが始まりですが、初心者の私に難しければ諦めて、一つ目のやり方を採用させて頂こうと考えています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問