ES6 テンプレート リテラルの実行の遅延
ES6 テンプレート リテラルは文字列補間のための強力な構文糖衣を提供しますが、評価を遅延したい場合はどうすればよいですか動的要素の作成後まで?
問題
従来、String.prototype.format を使用すると、遅延評価が可能でした。ただし、テンプレート リテラルは解析時に評価されるため、このアプローチは妨げられます。
解決策 1: タグ付きテンプレート リテラルを使用する
タグ付きテンプレート リテラルを使用すると、テンプレートをインターセプトして処理できます。評価前のリテラル:
function formatter(literals, ...substitutions) { return { format: function() { // ... code here ... } }; } console.log(formatter`Hello, <pre class="brush:php;toolbar:false">String.prototype.format = function() { var args = arguments; return this.replace(/$\{p(\d)\}/g, function(match, id) { return args[id]; }); }; console.log("Hello, ${p0}. This is a ${p1}".format("world", "test"));
解決策 2: プレーンな文字列リテラルを使用する
代わりに、プレーンな文字列リテラルを使用して置換を手動で解析することもできます:
const welcome = (p0, p1) => `Hello, ${p0}. This is a ${p1}`; console.log(welcome("world", "test"));
解決策 3: テンプレート リテラルを回避し、関数パラメーターを使用する
最後に、テンプレート リテラルを完全に回避して関数パラメーターを使用できます:
考慮事項
以上がES6 テンプレート リテラルの評価を延期するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。