Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Menukar Rentetan Secara Terprogram kepada Templat Literal dalam JavaScript dengan Selamat?

Bagaimanakah Saya Boleh Menukar Rentetan Secara Terprogram kepada Templat Literal dalam JavaScript dengan Selamat?

Patricia Arquette
Patricia Arquetteasal
2024-12-02 02:01:09494semak imbas

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

Menukar Rentetan kepada Rentetan Templat secara pengaturcaraan

Dalam Javascript, adalah mungkin untuk mentakrifkan templat rentetan menggunakan backticks ( ) atau. Walau bagaimanapun, dalam sesetengah senario, anda mungkin menghadapi situasi di mana anda mempunyai rentetan yang menyerupai rentetan templat tetapi bukan rentetan secara sintaksis.

Sebagai contoh, anda mungkin mempunyai rentetan yang menyerupai:

let a = "b:${b}";

Dan anda ingin menukarnya kepada rentetan templat yang sah kemudian.

Adalah penting untuk ambil perhatian bahawa menggunakan kaedah seperti eval atau baharu Fungsi untuk penjanaan kod dinamik tidak disyorkan atas sebab keselamatan. Sebaliknya. anda boleh memanfaatkan kaedah String.prototype.interpolate, dilaksanakan dalam ES6 seperti berikut:

String.prototype.interpolate = function(params) {
  const names = Object.keys(params);
  const vals = Object.values(params);
  return new Function(...names, `return \`${this}\`;`)(...vals);
};

Menggunakan kaedah ini, anda boleh mengubah rentetan anda dengan cara berikut:

let b = 10;
console.log(a.interpolate({ b }));

The output ialah b:10 yang menunjukkan interpolasi pembolehubah b yang berjaya ke dalam rentetan a.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menukar Rentetan Secara Terprogram kepada Templat Literal dalam JavaScript dengan Selamat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn