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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

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

Q&A

解決済

2回答

321閲覧

配列に文字列を加えた結果

tkshp

総合スコア174

JavaScript

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

0グッド

1クリップ

投稿2018/10/23 04:28

前提・実現したいこと

以下、3つの質問に関して、ご教示お願い致します。

・配列に文字列を加えると、「,」(カンマ)区切りで要素を連結した文字列に変換されるという認識で合っていますか?
・特に空文字列を加えた場合は、.join(',')したのと同等の結果という認識で合っていますか?

・また、配列に文字列を加えると文字列に変換されるという認識が合っていた場合、
要素間の区切り文字列は自動で「,」(カンマ)に決まってしまうのでしょうか?
文字列の加え方などによっては、要素間の区切り文字列を「,」(カンマ)以外のものに設定できたりするのでしょうか?
(joinメソッドを使えば、区切り文字列を設定できることはわかっています。)

余談ですが、配列に文字列を加えると文字列に変換されるという挙動(←合っていればの話ですが)、
JavaScriptぐらいですよね?
他の言語でこんな挙動にはならなかったような気がします。

試したこと

JavaScript

1var arr = ['要素1', '要素2', '要素3']; 2console.log(arr); //配列として出力される。 3console.log(arr[0]); //要素1 4 5//配列に文字列を足す。 6arr = arr+""; 7console.log("-----"); 8console.log(arr); //要素1,要素2,要素3 9console.log(arr[0]); //要

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

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

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

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

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

guest

回答2

0

ベストアンサー

・配列に文字列を加えると、「,」(カンマ)区切りで要素を連結した文字列に変換されるという認識で合っていますか?
・特に空文字列を加えた場合は、.join(',')したのと同等の結果という認識で合っていますか?

配列が持つ、.toString()メソッドの実装次第かと思います。
ということで、調べてみると

JavaScript 1.8.5 以降、および ECMAScript 第 5 版では、toString() メソッドは一般化されており、全てのオブジェクトで使用可能となっています。オブジェクトが join() メソッドを持つ場合はそれが呼び出され、その値が返されます。そうでない場合は Object.prototype.toString() が呼び出され、その結果の値が返されます。

引用: 「Array.prototype.toString()

とありました。ここで気になるのは、join()の引数です。同様に再度調べました。

str = arr.join([separator = ','])

引用: 「Array.prototype.join()

引数なしの場合、区切り文字は,(カンマ)になるようです。
こんな感じで調べることができます。

・また、配列に文字列を加えると文字列に変換されるという認識が合っていた場合、

要素間の区切り文字列は自動で「,」(カンマ)に決まってしまうのでしょうか?
文字列の加え方などによっては、要素間の区切り文字列を「,」(カンマ)以外のものに設定できたりするのでしょうか?
(joinメソッドを使えば、区切り文字列を設定できることはわかっています。)

toStringメソッドを上書きすればカンマ以外に設定できると思いますが、それはあまりいいことではないと思います。
ほかに詳しい人がいるかもしれません。

投稿2018/10/23 04:38

編集2018/10/23 04:40
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

tkshp

2018/10/23 04:44

ご回答ありがとうございます。 配列に文字列を加算することにより、toString()メソッドが呼び出されていたのですね。 オブジェクトが join() メソッドを持つ場合は、toString()メソッドの内部で、join() メソッドが呼び出されるのですね。
退会済みユーザー

退会済みユーザー

2018/10/23 04:47

ですです。yamabejpさんが言及されていますが、自動キャスト、暗黙的な型変換と呼ばれているみたいですね。調べると簡単な解説があるので面白いかもです。
tkshp

2018/10/23 04:49

ご回答ありがとうございます。 勉強になりました。
guest

0

配列に文字列を加えると文字列に変換されるという挙動

いわやる自動キャスト処理です
javascriptは数学的な加算も文字の連結も同じ「+」を利用するので
わかりづらいですが、キャストして同じ型にしてから連結してるだけでしょうね

ちゃんとやるなら

javascript

1var arr = ['要素1', '要素2', '要素3']; 2console.log(arr.toString());

でもこれもおかしな処理なのでできれば.join(",")でやるべきでしょう

投稿2018/10/23 04:40

yambejp

総合スコア114769

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

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

tkshp

2018/10/23 05:35 編集

ご回答ありがとうございます。 +で文字列を連結することにより、配列が文字列にキャストされて、その後に文字列を連結しているということですね。流れが理解できました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問