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

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

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

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

JavaScript

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

TypeScript

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

Q&A

1回答

1795閲覧

JavaScript(TypeScript)で文字列内のパラメータを埋めるようなフォーマットをしたい

koikuti

総合スコア50

Node.js

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

JavaScript

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

TypeScript

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

0グッド

0クリップ

投稿2021/12/17 07:44

前提・実現したいこと

JavaScript(TypeScript)で、文字列をフォーマットしたい。
※実際開発で使用しているのはTypeScriptになります。

例えばですが、

String.format('${name}です。${country}に住んでいます。', {name: "山田太郎", country: "日本"}); // 出来上がる文字列は、 『山田太郎です。日本に住んでいます。』 // ※ ${name} などの書き方は別の書き方かもしれません、あくまで例です。 // できれば、第2引数で渡すオブジェクト名とリンクしてくれると嬉しい。

のうようなフォーマット機能、あるいは実現できるライブラリはないのでしょうか?

javaなどだとあると思っているのですが、ちょっと調べた感じでは、
JavaScriptでは基本機能としても、ライブラリとしても提供されてないように思えました。

実際がどんな状況かというと、
jsonファイルでメッセージ一覧を管理し、このメッセージが上記のようなパラメータ含みで書かれており、
実際のコード上でログを出す際に適宜パラメータ部分を埋め込みたいというようなことになります。

※ メッセージ内容はこのjsonファイルを読み込んで取得するため、テンプレートリテラルで埋め込むということはできないと思っています。

試したこと

試したわけではないですが、ググった感じ自前でString.prototype.formに定義しようねといっ感じになっているなと認識しており、
他の言語では結構一般的にやりそうなのに、JavaScriptではみんな自前で用意してるの?
そもそも、こんな機能あまり求められてないの?
と不思議に思い質問冴えていただきました。

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

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

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

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

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

guest

回答1

0

死ぬほど不便ですよね。

各ブラウザが自前でJavaScriptエンジン作る時に
これが仕様書だからこの通りに動作するエンジンつくれよというものがあります。
その仕様書的な存在がECMAScript(以下ES)です。

最近2015年に出たES2015というバージョンにて
テンプレートリテラルという機能が実装され、多くのブラウザで使えるようになっています。
質問文のコードで言うとこんなことが出来るようになりました。

js

1const {name, country} = {name: "山田太郎", country: "日本"}; 2`${name}です。${country}に住んでいます。` 3 4// 出来上がる文字列は、 『山田太郎です。日本に住んでいます。』

Node.jsは既にES2020という最新に近い仕様まで取り込み終わっているので
テンプレートリテラルは利用可能です。

フロントエンドのIE11とかは対応していませんが、
TypeScriptを使っているのであれば、IE11相当でも動作するコードを出力するBabelモジュールを通すのでは?
その時にテンプレートリテラルは既存の"で括った文字列を+で愚直に繋ぐコードに変換してくれるので問題ありません。

歴史的背景として、JavaScriptは既に全世界で動作しています。
JavaScriptエンジンの改修で既存のWebサイトがエラーで閲覧できなくなったというのは困るので、
既存の構文を捨てて、良い挙動に変更することが出来ないという制約があるんですね。

なので"'ではどうにもならず、
バッククォート(JISキーボード時: Shift+@)で挟むみたいな新仕様を作って対応したという経緯となっています。

投稿2021/12/17 10:06

miyabi-sun

総合スコア21158

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問