--- title: String.prototype.indexOf() slug: Web/JavaScript/Reference/Global_Objects/String/indexOf translation_of: Web/JavaScript/Reference/Global_Objects/String/indexOf ---
indexOf()
method mengembalikan sebuah index saat memanggil objek {{jsxref("String")}} pertama kali dengan value yang di tentukan, bermula dari pencarian pada fromIndex
. Dan pencarian ini akan mengembalikan index dari karakter pada String, dan akan mengembalikan -1 ketika pencarian indexOf ini tak menemukan karakter yang cocok/ value yang sesuai.
str.indexOf(searchValue[, fromIndex]
)
searchValue
fromIndex
{{optional_inline}}0
, jadi seluruh index dari array akan dicari. Jika fromIndex < 0
seluruh string dicari. Jika fromIndex >= str.length
, string tidak dicari dan -1
sebagai kembaliannya. Kecuali kalau searchValue
adalah string kosong, maka str.length
sebagai kembaliannya.Karakter dalam sebuah string di indeks berurutan dari kiri ke kanan. Index pada karakter pertama yaitu 0, dan index pada karakter terakhir dalam sebuah String di sebut stringName is stringName.length - 1
.
'Blue Whale'.indexOf('Blue'); // mengembalikan 0 'Blue Whale'.indexOf('Blute'); // mengembalikan -1 'Blue Whale'.indexOf('Whale', 0); // mengembalikan 5 'Blue Whale'.indexOf('Whale', 5); // mengembalikan 5 'Blue Whale'.indexOf('', 9); // mengembalikan 9 'Blue Whale'.indexOf('', 10); // mengembalikan 10 'Blue Whale'.indexOf('', 11); // mengembalikan 10
The indexOf()
method sangat case sensitive. Sebagai contoh, expression berikut ini mengembalikan -1:
'Blue Whale'.indexOf('blue'); // mengembalikan -1
Catat bahwa '0' tak bernilai true dan '-1' bukan bernilali false
. Oleh karena-nya, ketika memeriksa apakah sebuah String Therefore, when checking if a specific string exists within another string the correct way to check would be:
'Blue Whale'.indexOf('Blue') !== -1; // true 'Blue Whale'.indexOf('Bloe') !== -1; // false
indexOf()
and lastIndexOf()
The following example uses indexOf()
and {{jsxref("String.prototype.lastIndexOf()", "lastIndexOf()")}} to locate values in the string "Brave new world"
.
var anyString = 'Brave new world'; console.log('The index of the first w from the beginning is ' + anyString.indexOf('w')); // logs 8 console.log('The index of the last w from the beginning is ' + anyString.lastIndexOf('w')); // logs 10 console.log('The index of "new" from the beginning is ' + anyString.indexOf('new')); // logs 6 console.log('The index of "new" from the end is ' + anyString.lastIndexOf('new')); // logs 6
indexOf()
and case-sensitivityThe following example defines two string variables. The variables contain the same string except that the second string contains uppercase letters. The first {{domxref("console.log()")}} method displays 19. But because the indexOf()
method is case sensitive, the string "cheddar"
is not found in myCapString
, so the second console.log()
method displays -1.
var myString = 'brie, pepper jack, cheddar'; var myCapString = 'Brie, Pepper Jack, Cheddar'; console.log('myString.indexOf("cheddar") is ' + myString.indexOf('cheddar')); // logs 19 console.log('myCapString.indexOf("cheddar") is ' + myCapString.indexOf('cheddar')); // logs -1
indexOf()
to count occurrences of a letter in a stringThe following example sets count
to the number of occurrences of the letter e
in the string str
:
var str = 'To be, or not to be, that is the question.'; var count = 0; var pos = str.indexOf('e'); while (pos !== -1) { count++; pos = str.indexOf('e', pos + 1); } console.log(count); // displays 4
Specification | Status | Comment |
---|---|---|
{{SpecName('ES1')}} | {{Spec2('ES1')}} | Initial definition. |
{{SpecName('ES5.1', '#sec-15.5.4.7', 'String.prototype.indexOf')}} | {{Spec2('ES5.1')}} | |
{{SpecName('ES6', '#sec-string.prototype.indexof', 'String.prototype.indexOf')}} | {{Spec2('ES6')}} | |
{{SpecName('ESDraft', '#sec-string.prototype.indexof', 'String.prototype.indexOf')}} | {{Spec2('ESDraft')}} |
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Basic support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} |