ホームページ >ウェブフロントエンド >jsチュートリアル >プログラムで文字列を JavaScript のテンプレート リテラルに安全に変換するにはどうすればよいですか?

プログラムで文字列を JavaScript のテンプレート リテラルに安全に変換するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-02 02:01:09561ブラウズ

How Can I Programmatically Convert a String to a Template Literal in JavaScript Safely?

プログラムによる文字列のテンプレート文字列への変換

JavaScript では、バックティック ( ) またはを使用して文字列テンプレートを定義できます。ただし、シナリオによっては、テンプレート文字列に似ているが構文的には異なる文字列があるという状況に遭遇することがあります。

たとえば、

let a = "b:${b}";
そして、後でそれを有効なテンプレート文字列に変換したいとします。

eval や new Function などのメソッドを使用することに注意することが重要です。動的コード生成は、セキュリティ上の理由から推奨されません。その代わり。 ES6 に実装されている String.prototype.interpolate メソッドを次のように利用できます:

String.prototype.interpolate = function(params) {
  const names = Object.keys(params);
  const vals = Object.values(params);
  return new Function(...names, `return \`${this}\`;`)(...vals);
};
このメソッドを利用すると、次の方法で文字列を変換できます:

let b = 10;
console.log(a.interpolate({ b }));
出力は b:10 となり、変数 b の文字列 a への補間が成功したことがわかります。

以上がプログラムで文字列を JavaScript のテンプレート リテラルに安全に変換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。