この記事は編集レビューを必要としています。ぜひご協力ください。
この翻訳は不完全です。英語から この記事を翻訳 してください。
これは Harmony(ECMAScript 6) 提案の一部であり、実験段階の技術です。
この技術の仕様は安定していません。ブラウザ互換性の一覧表を確認してください。またこれらの構文や動作は、仕様変更などにより、新しいバージョンのブラウザでは変更される可能性があるという点に注意してください。
概要
引数の二乗和の平方根を返します。すなわち
構文
Math.hypot([value1[, value2[, ...]]])
引数
value1, value2, ...
- 数値
説明
hypot()
はMath
オブジェクトの静的なメソッドなので、自ら生成したMath
オブジェクトのメソッドとしてではなく、常に、Math.hypot()
として使用するようにしてください(Math
オブジェクトにはコンストラクタがありません)。
引数が与えられないなら、結果は+0となります。
少なくとも引数のうち1つが数値に変換できないなら、結果はNaN
になります。
ひとつの引数では、Math.hypot()
はMath.abs()
と同じ結果となります。
例
例: Math.hypot()
を使う
Math.hypot(3, 4); // 5 Math.hypot(3, 4, 5); // 7.0710678118654755 Math.hypot(); // 0 Math.hypot(NaN); // NaN Math.hypot(3, 4, 'foo'); // NaN, +'foo' => NaN Math.hypot(3, 4, '5'); // 7.0710678118654755, +'5' => 5 Math.hypot(-3); // 3, the same as Math.abs(-3)
ポリフィル
次の関数を使用することでエミュレートできます。:
Math.hypot = Math.hypot || function() { var y = 0; var length = arguments.length; for (var i = 0; i < length; i++) { if (arguments[i] === Infinity || arguments[i] === -Infinity) { return Infinity; } y += arguments[i] * arguments[i]; } return Math.sqrt(y); };
仕様
仕様 | 状況 | コメント |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) The definition of 'Math.hypot' in that specification. |
Standard | Initial definition. |
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
基本サポート | 38 | 27 (27) | 未サポート | 25 | 7.1 |
機能 | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
基本サポート | 未サポート | 未サポート | 27.0 (27) | 未サポート | 未サポート | iOS 8 |