関数が JavaScript ネイティブ関数かどうかを検出するためのヒント function_javascript のヒント

WBOY
リリース: 2016-05-16 16:09:57
オリジナル
1053 人が閲覧しました

私の開発作業では、関数が JavaScript ネイティブ関数であるかどうかを判断する必要がある状況によく遭遇します。これは、関数がブラウザー自体によって提供されているかどうかを知る必要がある場合があります。サードパーティによるカプセル化とネイティブ関数としての偽装。もちろん、最も良い方法は、この関数を実行する toString メソッドの戻り値を調べることです。

JavaScript

このタスクを完了する方法は非常に簡単です:

コードをコピー コードは次のとおりです:

関数 isNative(fn) {
return (/{s*[ネイティブコード]s*}/).test('' fn);
}

toString メソッドは、このメソッドの文字列形式を返し、正規表現を使用してそれに含まれる文字を特定します。

より強力な方法

Lodash の創設者 John-David Dalton は、より良いソリューションを発見しました:

コードをコピーします コードは次のとおりです:

;(関数() {

// 値の内部 `[[Class]]` を解決するために使用されます
var toString = Object.prototype.toString;

// 逆コンパイルされた関数のソースを解決するために使用されます
var fnToString = Function.prototype.toString;

// ホスト コンストラクターの検出に使用されます (Safari > 4; 実際に型指定された配列固有)
var reHostCtor = /^[オブジェクト . ?コンストラクター]$/;

// 一般的なネイティブ メソッドをテンプレートとして使用して正規表現をコンパイルします。
// `Object#toString` を選択したのは、改ざんされていない可能性が高いためです。
var reNative = RegExp('^'
// `Object#toString` を文字列に強制変換します
文字列(toString)
// 特殊な正規表現文字をエスケープします
.replace(/[.* ?^${}()|[]/\]/g, '\$&')
// テンプレートを汎用性を保つために、`toString` の言及を `.*?` に置き換えます。
// 追加情報を追加する Rhino のような環境をサポートするには、「for ...」 のようなものを置き換えます
// メソッドのアリティなど。
.replace(/toString|(function).*?(?=\()| for . ?(?=\])/g, '$1.*?') '$'
);

関数 isNative(value) {
var type = 値の型;
戻り値の型 == '関数'
// `Function#toString` を使用して、値自体の `toString` メソッドをバイパスします
// なりすましを回避します。
? reNative.test(fnToString.call(value))
// 環境によっては
を表すため、ホスト オブジェクト チェックにフォールバックします。 // DOM メソッドとしての型付き配列など、
に準拠していない可能性のあるもの // 通常のネイティブ パターン。
: (値 && タイプ == 'オブジェクト' && reHostCtor.test(toString.call(value))) ||
}

// 必要に応じてエクスポートします
module.exports = isNative;
}());


ご覧のとおり、これは複雑ですが、より強力です。もちろん、これはセキュリティ目的ではなく、ネイティブ関数かどうかに関する情報を提供するだけです。
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート