ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript の一般的な定義とメソッド

JavaScript の一般的な定義とメソッド

巴扎黑
巴扎黑オリジナル
2017-06-26 15:02:011320ブラウズ

1. いくつかの一般的な文字列メソッド。これらのメソッドを呼び出すと、元の文字列の内容は変更されませんが、新しい文字列が返されることに注意してください。
toUpperCase()
文字列をすべて大文字に変換します:

var s = 'Hello';
s.toUpperCase(); // 返回'HELLO'


toLowerCase()
文字列をすべて小文字に変換します:

var s = 'Hello';var lower = s.toLowerCase(); // 返回'hello'并赋值给变量lowerlower; // 'hello'


indexOf()
は、指定された文字列の出現を検索します 位置:

var s = 'hello, world';
s.indexOf('world'); // 返回7s.indexOf('World'); // 没有找到指定的子串,返回-1


substring()
指定されたインデックス範囲の部分文字列を返します:

var s = 'hello, world's.substring(0, 5); // 从索引0开始到5(不包括5),返回'hello's.substring(7); // 从索引7开始到结束,返回'world'


2. 指定された要素の位置を検索する一般的な配列メソッド
indexOf()

var arr = [10, 20, '30', 'xyz'];
arr.indexOf(10); // 元素10的索引为0arr.indexOf(20); // 元素20的索引为1arr.indexOf(30); // 元素30没有找到,返回-1arr.indexOf('30'); // 元素'30'的索引为2


スライス()
配列の一部の要素をインターセプトし、新しい配列を返します:

var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
arr.slice(0, 3); // 从索引0开始,到索引3结束,但不包括索引3: ['A', 'B', 'C']arr.slice(3); // 从索引3开始到结束: ['D', 'E', 'F', 'G']

slice() の開始パラメーターと終了パラメーターには開始インデックスが含まれますが、終了インデックスは含まれないことに注意してください。
slice() にパラメータを渡さない場合、最初から最後まですべての要素がインターセプトされます。これを利用して、配列を簡単にコピーできます。

push と Pop
push() は配列の末尾にいくつかの要素を追加し、pop() は配列の最後の要素を削除します: 現在の要素に対して

var arr = [1, 2];
arr.push('A', 'B'); // 返回Array新的长度: 4arr; // [1, 2, 'A', 'B']arr.pop(); // pop()返回'B'arr; // [1, 2, 'A']arr.pop(); arr.pop(); arr.pop(); // 连续pop 3次arr; // []arr.pop(); // 空数组继续pop不会报错,而是返回undefinedarr; // []


unshift と SHIFT

var arr = [1, 2];
arr.unshift('A', 'B'); // 返回Array新的长度: 4arr; // ['A', 'B', 1, 2]arr.shift(); // 'A'arr; // ['B', 1, 2]arr.shift(); arr.shift(); arr.shift(); // 连续shift 3次arr; // []arr.shift(); // 空数组继续shift不会报错,而是返回undefinedarr; // []

sort
配列のソートは、現在の配列の要素の位置を直接変更します。直接呼び出すと、デフォルトの順序でソートされます:

var arr = ['B', 'C', 'A'];
arr.sort();
arr; // ['A', 'B', 'C']

reverse
配列全体の要素を削除します。つまり、逆にします:

var arr = ['one', 'two', 'three'];
arr.reverse();
arr; // ['three', 'two', 'one']


splice
Arrayの「ユニバーサルメソッド」を変更します。これにより、指定されたインデックスから始まるいくつかの要素を削除し、その位置からいくつかの要素を追加できます

var arr = ['Microsoft', 'Apple', 'Yahoo', 'AOL', 'Excite', 'Oracle'];// 从索引2开始删除3个元素,然后再添加两个元素:arr.splice(2, 3, 'Google', 'Facebook'); // 返回删除的元素 ['Yahoo', 'AOL', 'Excite']arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']// 只删除,不添加:arr.splice(2, 2); // ['Google', 'Facebook']arr; // ['Microsoft', 'Apple', 'Oracle']// 只添加,不删除:arr.splice(2, 0, 'Google', 'Facebook'); // 返回[],因为没有删除任何元素arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']


concat
現在のArrayを別のArrayに接続し、新しい配列を返します

var arr = ['A', 'B', 'C'];var added = arr.concat([1, 2, 3]);
added; // ['A', 'B', 'C', 1, 2, 3]arr; // ['A', 'B', 'C']


join

var arr = ['A', 'B', 'C', 1, 2, 3];
arr.join('-'); // 'A-B-C-1-2-3'


3. オブジェクト
JavaScriptオブジェクトは動的に型付けされるため、オブジェクトに属性を自由に追加または削除できます:

var xiaoming = {
    name: '小明'};
xiaoming.age; // undefinedxiaoming.age = 18; // 新增一个age属性xiaoming.age; // 18delete xiaoming.age; // 删除age属性xiaoming.age; // undefineddelete xiaoming['name']; // 删除name属性xiaoming.name; // undefineddelete xiaoming.school; // 删除一个不存在的school属性也不会报错


xiaomingがそれを持っているかどうかを検出します特定の属性に対して、in 演算子を使用できます:

var xiaoming = {
    name: '小明',
    birth: 1990,
    school: 'No.1 Middle School',
    height: 1.70,
    weight: 65,
    score: null};'name' in xiaoming; // true'grade' in xiaoming; // false

ただし、in が属性が存在すると判断した場合、この属性は必ずしも xiaoming に属しているわけではなく、xiaoming から継承される可能性があることに注意してください。属性は xiaoming 継承ではなく自分で所有され、hasOwnProperty() メソッドを使用できます:

var xiaoming = {
    name: '小明'};
xiaoming.hasOwnProperty('name'); // truexiaoming.hasOwnProperty('toString'); // false

ES6 標準に新しいデータ型が導入されました Map、Set

var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);
m.get('Michael'); // 95var s1 = new Set(); // 空Setvar s2 = new Set([1, 2, 3]); // 含1, 2, 3

ES6 標準に新しい反復可能な型が導入されました (Yidai できます) )
配列、マップ、セットはすべて反復可能型に属します。
新しい for...of ループを通過します

var a = ['A', 'B', 'C'];var s = new Set(['A', 'B', 'C']);var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);for (var x of a) { // 遍历Array    alert(x);
}for (var x of s) { // 遍历Set    alert(x);
}for (var x of m) { // 遍历Mapalert(x[0] + '=' + x[1]);
}

4. Function
Free キーワード引数。これは関数内でのみ機能し、常に現在の関数の呼び出し元によって渡されるすべてのパラメーターを指します。 argument は Array に似ていますが、Array ではありません。

function foo(x) {
    alert(x); // 10for (var i=0; i<arguments.length; i++) {
        alert(arguments[i]); // 10, 20, 30    }
}
foo(10, 20, 30);

Max は、2 つの数値のうち大きい方を返す max() 関数を作成しました。変数スコープ
ES6 では、var の代わりに let を使用します。ブロックレベルのスコープ変数を宣言する

document.write(Math.max(7.25,7.30));


ES6標準では、定数を定義する新しいキーワードconstが導入されており、constとletの両方にブロックレベルのスコープがあります

&#39;use strict&#39;;function foo() {var sum = 0;for (let i=0; i<100; i++) {
        sum += i;
    }
    i += 1; // SyntaxError}

6。高度な関数
map()メソッドはJavaScript Array で定義された Array の map() メソッドを呼び出し、独自の関数を渡し、結果として新しい Array を取得します。

const PI = 3.14;
PI = 3; // 某些浏览器不报错,但是无效果!PI; // 3.14


reduce() は、この配列の [x1, x2, x3...] に関数を適用します。この関数は 2 つのパラメーターを受け取り、その結果をシーケンスの次の要素に継続します。累積計算の処理は次のとおりです。

function pow(x) {return x * x;
}var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
arr.map(pow); // [1, 4, 9, 16, 25, 36, 49, 64, 81]

フィルターも、配列の特定の要素をフィルターで除外し、残りの要素を返すために使用されます。
渡された関数を各要素に順番に適用し、戻り値が true か false かに基づいて要素を保持するか破棄するかを決定します。

たとえば、配列内で偶数を削除し、奇数のみを保持します
[x1, x2, x3, x4].reduce(f) = f(f(f(x1, x2), x3), x4)var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {return x + y;
}); // 25



配列内の空の文字列を削除するには、次のように記述できます:

var arr = [1, 2, 4, 5, 6, 9, 10, 15];var r = arr.filter(function (x) {return x % 2 !== 0;
});
r; // [1, 5, 9, 15]

匿名関数 (関数名なし Function)

var arr = [&#39;A&#39;, &#39;&#39;, &#39;B&#39;, null, undefined, &#39;C&#39;, &#39;  &#39;];var r = arr.filter(function (s) {return s && s.trim(); // 注意:IE9以下的版本没有trim()方法});
r; // [&#39;A&#39;, &#39;B&#39;, &#39;C&#39;]

ソート並べ替えアルゴリズム

var friends = ["Mike", "Stacy", "Andy", "Rick"];

friends.forEach(function (eachName, index){
console.log(index + 1 + ". " + eachName); // 1. Mike, 2. Stacy, 3. Andy, 4. Rick});


第二个排序把apple排在了最后,是因为字符串根据ASCII码进行排序,而小写字母a的ASCII码在大写字母之后。
第三个排序结果是什么鬼?简单的数字排序都能错?
这是因为Array的sort()方法默认把所有元素先转换为String再排序,结果'10'排在了'2'的前面,因为字符'1'比字符'2'的ASCII码小。

7闭包
高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回

function lazy_sum(arr) {var sum = function () {return arr.reduce(function (x, y) {return x + y;
        });
    }return sum;
}


当我们调用lazy_sum()时,返回的并不是求和结果,而是求和函数:

var f = lazy_sum([1, 2, 3, 4, 5]); // function sum()

调用函数f时,才真正计算求和的结果:

f(); // 15


在函数lazy_sum中又定义了函数sum,并且,内部函数sum可以引用外部函数lazy_sum的参数和局部变量,当lazy_sum返回函数sum时,相关参数和变量都保存在返回的函数中,这种称为“闭包(Closure)”的程序结构拥有极大的威力。

请再注意一点,当我们调用lazy_sum()时,每次调用都会返回一个新的函数,即使传入相同的参数:

var f1 = lazy_sum([1, 2, 3, 4, 5]);var f2 = lazy_sum([1, 2, 3, 4, 5]);
f1 === f2; // false

f1()和f2()的调用结果互不影响。

8.箭头函数
ES6标准新增了一种新的函数:Arrow Function(箭头函数)。
为什么叫Arrow Function?因为它的定义用的就是一个箭头:
x => x * x
上面的箭头函数相当于:

function (x) {return x * x;
}


generator(生成器)是ES6标准引入的新的数据类型。一个generator看上去像一个函数,但可以返回多次。

function* foo(x) {
    yield x + 1;
    yield x + 2;return x + 3;
}

函数在执行过程中,如果没有遇到return语句(函数末尾如果没有return,就是隐含的return undefined;),控制权无法交回被调用的代码。









以上がJavaScript の一般的な定義とメソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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