目次
eval() を使用しない JavaScript での文字列値の計算
Function() コンストラクターの使用
このアプローチの利点
ホームページ ウェブフロントエンド jsチュートリアル eval() を使用せずに JavaScript で文字列式を評価する方法

eval() を使用せずに JavaScript で文字列式を評価する方法

Nov 14, 2024 pm 10:31 PM

How to Evaluate String Formulas in JavaScript Without Using eval()?

eval() を使用しない JavaScript での文字列値の計算

数式を含む文字列の評価は、プログラミングにおける一般的なタスクです。 JavaScript はそのような目的のために eval() 関数を提供しますが、セキュリティ上のリスクが生じるため、一般的には推奨されません。ここでは、eval() を使用せずに文字列値を計算する別のアプローチを示します。

Function() コンストラクターの使用

Function() コンストラクターは、文字列から匿名関数を作成できます。これは文字列式を評価するために利用できます。たとえば、次のコードについて考えてみましょう。

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

console.log(evil('12/5*9+9.4*2')); // => 40.4
ログイン後にコピー

Function() コンストラクターによって評価された新しい関数を返すことで、文字列に格納された数学演算を実行できます。この例では、文字列 "12/5*9 9.4*2" は 40.4 と評価されます。

このアプローチの利点

eval() と比較して、Function() コンストラクターでは次のことが可能です。 :

  • セキュリティの強化: Function() コンストラクターを使用して文字列を評価すると、任意のコードを実行できる eval() に関連する潜在的なセキュリティ脆弱性が回避されます。
  • 型安全性: Function() コンストラクターは、実行前に文字列引数の構文をチェックし、型安全性を強化します。

一方、Function() コンストラクターは、より安全で信頼性の高い代替手段を提供します。 eval() を使用する場合でも、コードは動的に評価されることに注意することが重要です。そのため、悪意のある入力を避けるために予防措置を講じる必要があります。

以上がeval() を使用せずに JavaScript で文字列式を評価する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JavaScriptの文字列文字を交換します JavaScriptの文字列文字を交換します Mar 11, 2025 am 12:07 AM

JavaScriptの文字列文字を交換します

カスタムGoogle検索APIセットアップチュートリアル カスタムGoogle検索APIセットアップチュートリアル Mar 04, 2025 am 01:06 AM

カスタムGoogle検索APIセットアップチュートリアル

例JSONファイルの例 例JSONファイルの例 Mar 03, 2025 am 12:35 AM

例JSONファイルの例

8見事なjQueryページレイアウトプラグイン 8見事なjQueryページレイアウトプラグイン Mar 06, 2025 am 12:48 AM

8見事なjQueryページレイアウトプラグイン

10 jQuery構文蛍光物 10 jQuery構文蛍光物 Mar 02, 2025 am 12:32 AM

10 jQuery構文蛍光物

' this' JavaScriptで? ' this' JavaScriptで? Mar 04, 2025 am 01:15 AM

' this' JavaScriptで?

独自のAjax Webアプリケーションを構築します 独自のAjax Webアプリケーションを構築します Mar 09, 2025 am 12:11 AM

独自のAjax Webアプリケーションを構築します

10 JavaScript&JQuery MVCチュートリアル 10 JavaScript&JQuery MVCチュートリアル Mar 02, 2025 am 01:16 AM

10 JavaScript&JQuery MVCチュートリアル

See all articles