Rumah > hujung hadapan web > tutorial js > Bagaimanakah Anda Boleh Menilai Formula Rentetan dengan Selamat dalam JavaScript Tanpa Menggunakan Eval()?

Bagaimanakah Anda Boleh Menilai Formula Rentetan dengan Selamat dalam JavaScript Tanpa Menggunakan Eval()?

Susan Sarandon
Lepaskan: 2024-11-13 08:00:02
asal
240 orang telah melayarinya

How Can You Safely Evaluate String Formulas in JavaScript Without Using Eval()?

Menilai Nilai Rentetan dalam JavaScript tanpa Eval

Fungsi eval() dalam JavaScript menimbulkan risiko keselamatan dan boleh membawa kepada suntikan kod. Untuk mengelakkan isu ini, adalah disyorkan untuk meneroka kaedah alternatif untuk menilai rentetan formula.

Salah satu alternatif tersebut ialah pembina Function(), yang boleh menilai rentetan kod dan mengembalikan hasilnya. Sebagai contoh, pertimbangkan formula rentetan berikut:

var apa = "12/5*9+9.4*2";
Salin selepas log masuk

Daripada menggunakan eval(apa), anda boleh menggunakan pembina Function() untuk mencipta fungsi baharu yang mewakili formula:

function evil(fn) {
  return new Function('return ' + fn)();
}

console.log(evil('12/5*9+9.4*2')); // => 40.4
Salin selepas log masuk

Pembina Function() mengambil rentetan kod sebagai hujah dan mengembalikan objek fungsi. Kenyataan pulangan dalam rentetan memastikan bahawa hasil formula dikembalikan. Fungsi console.log() kemudiannya memaparkan hasil yang dinilai.

Menggunakan pembina Function() ialah alternatif yang lebih selamat kepada eval() kerana ia tidak melaksanakan kod sembarangan daripada rentetan. Ia menyediakan cara yang lebih terkawal dan boleh diramal untuk menilai ungkapan rentetan dalam JavaScript.

Atas ialah kandungan terperinci Bagaimanakah Anda Boleh Menilai Formula Rentetan dengan Selamat dalam JavaScript Tanpa Menggunakan Eval()?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan