ホームページ > php教程 > php手册 > js上で通常の関数を呼び出す方法をコードで添付します

js上で通常の関数を呼び出す方法をコードで添付します

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-13 12:28:42
オリジナル
815 人が閲覧しました

ECMAScript 4 提案では、この機能が ES4 仕様に追加されると述べられていましたが、後の ES4 ディスカッション メーリング リストの議論の中で、この提案は放棄される可能性があります。

ただし、RegExp.prototype に call メソッドと apply メソッドを追加することで、同様にこれらのメソッドを実装できます。機能設計に役立つだけでなく、関数と正規表現の両方に有効なダックタイプ コードの実装も可能になります。そこで、これらのメソッドを追加しましょう。

RegExp.prototype.call = function (context, str) {
return this.exec(str);
RegExp.prototype.apply = function (context, args) {
return this.exec(args[0]);
}; 上記の 2 つのメソッドは、コンテキスト パラメーターを完全に無視することができ、同様の通常のオブジェクトが得られます。 execメソッドの戻り値。上記の方法を使用すると、どのような状況でも正規表現や関数を通常どおりに使用することが非常に簡単になります。これらのようないくつかの明白な例は、JavaScript 1.6 での配列の反復に役立ちます。次のフィルター、every、some、map メソッドは、ブラウザー間で実行できます。

if (!Array.prototype.filter) {
// 配列を返します。指定されたフィルター関数が true を返した場合は、既存の配列の要素を返します。
Array.prototype.filter = Function (func, context) {
var results = [];
for (var I = 0; I & lt; projecth; i) {
if (if i in this && func.call(context, this[i], i, this))
results.push(this[i])
}
結果を返します。 >}

if (!Array.prototype.every) {
// 配列内の各要素が提供されたテスト関数を満たす場合は true を返します。
Array.prototype.every = function (func, context) {
for (var i = 0; i if (i in this && !func.call( context, this[i], i, this))
return false;
return true;
if (!Array.prototype.some) {
// true を返します。配列内の少なくとも 1 つの要素が提供されたテスト関数を満たすかどうか。
Array.prototype.some = function (func, context) {
for (var i = 0; i if (i in this && func.call(context) , this[i], i, this))
true を返す;
};

if (!Array.prototype.map ) {
// 配列を返します。既存の配列の各要素は、指定された関数の戻り値を呼び出します。
Array.prototype.map = function (func, context) {
var results = [];
for (var i = 0; i if ( i in this)
results[i] = func.call(context, this[i], i, this);
}
は結果を返します。 exec メソッド true および false への適切な型変換を行って、配列または null 値を返します。上記のコードでは、["a","b","ab","ba"].filter(/) のように使用できます。 ^a/ )、「a」で始まるすべての値を返します: ["a","ab"]。

実際、Array.prototype.filter は Firefox に実装されています。これは、exec の間接呼び出しがこのブラウザですでに機能しているためです。ただし、フィルターに RegExp.prototype.call メソッドが追加されていない場合、ブラウザーをまたいで実行することはできません。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
下線
から 1970-01-01 08:00:00
0
0
0
フォームを下に揃える方法
から 1970-01-01 08:00:00
0
0
0
JavaScript - isscroll5 上下の問題
から 1970-01-01 08:00:00
0
0
0
tink の下に DB ファイルがありません
から 1970-01-01 08:00:00
0
0
0
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート