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

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

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

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

Q&A

解決済

4回答

753閲覧

Javascriptにおいて行の最後には";"をつけるべきか、文字列はシングルとダブルどちらのクオートで囲むのが良いか

sakapun

総合スコア888

JavaScript

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

1グッド

2クリップ

投稿2018/01/01 13:58

わりと宗教論な気もするのですが、どちらのほうが好まれているのでしょうか。
ESlintの標準に従えといえばそれまでですが、きちんと納得できる理由があればもっと腑に落ちるので、ぜひ具体的な理由も教えて頂ければと思います。
個人的にはセミコロン付ける派で、ダブルクオートの方が好きなのですが、Nuxt.jsをインストールしたら両方逆だったので本当に従うべきなのか、趣向により潰していいのか気になります

DrqYuto👍を押しています

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

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

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

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

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

guest

回答4

0

どちらにするかは自由ですが、全体のルールを統一することが重要です。

JavaScriptではダブルクオートもシングルクオートも意味差はないのですが、RubyやPHPなどで「何も特殊効果のない文字列はシングルクオート」というのに慣れていたので、シングルクオートが途中に登場しない文字列はシングルクオートで書いています。

JavaScriptの「セミコロンの自動挿入」は、「つなげるものはつなぐ(一部例外あり)」という、中途半端さもあるルールなので、入れる入れないのどちらにしても注意が必要です。

  • セミコロンありで書く場合…引数をつけるreturnbreakcontinuethrowのあと、後置インクリメント・デクリメントの直前では改行しない(ここで改行すると、セミコロンが自動挿入される)
  • セミコロンなしで書く場合…行頭に[(、単項プラスを置かない(前の行につながる)

投稿2018/01/01 23:40

maisumakun

総合スコア145184

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

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

0

ベストアンサー

JavaScriptは、「行末にセミコロンが無い場合、次の行と繋いで文法的に通るなら繋ぐ」という言語なので、セミコロンを付けないと意図せず次の行とつながって解釈される可能性があります。
従って、文の切れ目の場合は付けた方が良いです。
もちろん、毎回、「ここは付けないと次の行とつながるかどうか」を判断してもいいのですが。

引用符は好みでしょう。よく使われているフォントでは一重引用符は左右対称じゃ無いので(まあ、本来はアポストロフィなので当然ですが)、私は二重引用符を好みますが、多くの人はなぜか左右対称にこだわらず、一重引用符を使うようです。

投稿2018/01/01 21:53

otn

総合スコア84557

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

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

sakapun

2018/01/02 17:13

セミコロンの有る無しの文法的な危険性、引用符はどちらでも良いというお答えのお二人の中から早めにご回答いただいたのでベストアンサーとさせて頂きました。
guest

0

個人的にはセミコロン派ですね。cssでは最後以外は必須なので頭の切り替えが面倒と言うのと、やったことはないですがjsファイルの圧縮後にインデントや改行を戻し易いのではという単純な理由です。
文字列はシングルクオートですね。htmlの属性はダブルクオートというイメージからです。
ダブルクオートの方が利用機会が多そうなのでシングルクオートが好きです。

投稿2018/01/01 14:23

sousuke

総合スコア3828

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

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

0

あくまで個人的なルールなのですが、私はhtml、cssをダブルクォーテーション、jsをシングルクォーテーションで書きます。

理由ですが、HTML、cssでは一般的にダブルクォーテーションで括ることが多いように感じます。
その前提で考えると、js内で動的にhtml構造をアペンドまたは差し替えたりする時にjsもダブルクォーテーションで括ってしまうと、js内に記述したhtml構造のダブルクォーテーションをエスケープする必要が出てきてしまい、手間が増え、また可読性も悪くなってしまいます。

以上のことから、html、cssはダブルクォーテーション、jsはシングルクォーテーションで括るようにしています。
ただこれは冒頭に述べたようにあくまで個人的なルールですので、実務上ではチームやプロジェクトのルールに則ってコーディングすべきと思います。

投稿2018/01/01 14:29

sota_u

総合スコア88

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問