对Javascript indexOf函数使用的简单说明
使用方法:strObj.indexOf(str,startIndex[可选])
程序代码
其中strObj是必选项。String 对象或文字。
str是必选项。要在 String 对象中查找的子字符串。
startIndex是可选项。该整数值指出在 String 对象内开始查找的位置,从0开始。如果省略,则从字符串的开始处查找。
注意:对于JavaScript indexOf是区分大小写的。
JavaScript中indexOf函数方法返回一个整数值,指出 String 对象内子字符串的开始位置。如果没有找到字符串,则返回 -1。如果 startindex 是负数,则 startindex 被当作零。如果它比***的字符位置索引还大,则它被当作***的可能索引。
javascript indexOf函数是从左向右执行查找
下面的示例说明了indexOf函数方法的用法。
程序代码
- var str1="fdiejDIFADF";
- var str="e";
- var i=str1.indexOf(str);
- alert(i);
在前面说了,indexOf是区分大小的写,有时这就给我们造成了一定的麻烦,那怎么解决呢??当然最简单的方法是把字符用toLowerCase或toUpperCase转化为大写或小写就解决了。
代码如下:
程序代码
- <script>
- var Str = 'ABCDEF';
- var Str1 = 'bcd';
- alert(Str.toLowerCase().indexOf(Str1.toLowerCase()));
- str2 = 'AbCdEf';
- alert(Str2.toLowerCase().indexOf(Str1.toLowerCase()));
- script>
下面这个方法利用正则对indexOf进行了扩展(来自网络)
程序代码
- <script>
- String.prototype.indexOf = function(f,m){
- var mm = (m == false) ? "i":"";
- var re = eval("/"+ f +"/"+mm);
- var rt = this.match(re);
- return (rt == null) ? -1:rt.index;
- }
- var test = "absnegKIugfkalg";
- alert(test.indexOf("kiu",false));
- script>
下面的这个扩展就更强大了,它兼容原来的 indexOf函数,也可以进行忽略大小的查找(同样来自网络)。
程序代码
- <script language="javascript">
- StringString.prototype._indexOf = String.prototype.indexOf;
- String.prototype.indexOf = function()
- {
- if(typeof(arguments[arguments.length - 1]) != 'boolean')
- return this._indexOf.apply(this,arguments);
- else
- {
- var bi = arguments[arguments.length - 1];
- var thisthisObj = this;
- var idx = 0;
- if(typeof(arguments[arguments.length - 2]) == 'number')
- {
- idx = arguments[arguments.length - 2];
- thisthisObj = this.substr(idx);
- }
- var re = new RegExp(arguments[0],bi?'i':'');
- var r = thisObj.match(re);
- return r==null?-1:r.index + idx;
- }
- }
- alert("bcssssasdfsdf".indexOf('A',3,true));
- alert("bcssssasdfsdf".indexOf('a',3));
- script>
【编辑推荐】
- JavaScript中关于 Cookie的详细介绍
- JavaScript中 confirm,alert,prompt的用法
- 基于JavaScript的REST 客户端框架
- 如何优化JavaScript脚 本的性能
- 用Javascript连接 Access数据库的方法
版权声明:
作者:后浪云
链接:https://www.idc.net/help/411922/
文章版权归作者所有,未经允许请勿转载。
THE END