使用indexOf等在JavaScript的数组中进行元素查找和替换


Posted in Javascript onSeptember 18, 2013
<html> 
<head> 
<title> Extend JavaScript Array Method </title> 
<script language="javascript"> 
<!-- 
Array.prototype.indexOf=function(substr,start){ 
var ta,rt,d='\0'; 
if(start!=null){ta=this.slice(start);rt=start;}else{ta=this;rt=0;} 
var str=d+ta.join(d)+d,t=str.indexOf(d+substr+d); 
if(t==-1)return -1;rt+=str.slice(0,t).replace(/[^\0]/g,'').length; 
return rt; 
} Array.prototype.lastIndexOf=function(substr,start){ 
var ta,rt,d='\0'; 
if(start!=null){ta=this.slice(start);rt=start;}else{ta=this;rt=0;} 
ta=ta.reverse();var str=d+ta.join(d)+d,t=str.indexOf(d+substr+d); 
if(t==-1)return -1;rt+=str.slice(t).replace(/[^\0]/g,'').length-2; 
return rt; 
} 
Array.prototype.replace=function(reg,rpby){ 
var ta=this.slice(0),d='\0'; 
var str=ta.join(d);str=str.replace(reg,rpby); 
return str.split(d); 
} 
Array.prototype.search=function(reg){ 
var ta=this.slice(0),d='\0',str=d+ta.join(d)+d,regstr=reg.toString(); 
reg=new RegExp(regstr.replace(/\/((.|\n)+)\/.*/g,'\\0$1\\0'),regstr.slice(regstr.lastIndexOf('/')+1)); 
t=str.search(reg);if(t==-1)return -1;return str.slice(0,t).replace(/[^\0]/g,'').length; 
} 
window.onload=function(){ 
var a=new Array('aa1321321','b4323424b','cc345345','dd4654','dd4654','b4323424b'); 
document.getElementById('t1').value=a.toString(); 
//document.getElementById('t2').value=a.indexOf('cc345345'); 
//document.getElementById('t3').value=a.lastIndexOf('dd4654'); 
document.getElementById('t4').value=a.replace('b4323424b','*');//把第一个b4323424b替换成* 
document.getElementById('t5').value=a.search(/dd4654/);//未找到返回-1 
}; 
//--> 
</script> 
<style type="text/css"> 
<!-- 
input{width:600px} 
//--> 
</style> 
</head> 
<body> 
<table> 
<tr><td>数组a:</td><td><input id="t1" type="text" /></td></tr> 
<tr><td>a.indexOf('cc345345'):</td><td><input id="t2" type="text" /></td></tr> 
<tr><td>a.lastIndexOf('dd4654'):</td><td><input id="t3" type="text" /></td></tr> 
<tr><td>a.replace(/\d/g,'*'):</td><td><input id="t4" type="text" /></td></tr> 
<tr><td>a.search(/dd4654/):</td><td><input id="t5" type="text" /></td></tr> 
</table> 
</body> 
</html>
Javascript 相关文章推荐
JS 学习笔记 防止发生命名冲突
Jul 30 Javascript
jQuery Select(单选) 模拟插件 V1.3.62 改进版
Jul 17 Javascript
javascript:history.go()和History.back()的区别及应用
Nov 25 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
Nov 23 Javascript
jQuery标签替换函数replaceWith()的使用例子
Aug 28 Javascript
JavaScript取得键盘按下方向键是哪个的方法
Aug 04 Javascript
javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
Jan 03 Javascript
vue 2.0封装model组件的方法
Aug 03 Javascript
vue使用xe-utils函数库的具体方法
Mar 06 Javascript
Angular4集成ng2-file-upload的上传组件
Mar 14 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
Sep 06 Javascript
webpack proxy 使用(代理的使用)
Jan 10 Javascript
JSON 数字排序多字段排序介绍
Sep 18 #Javascript
json数据与字符串的相互转化示例
Sep 18 #Javascript
如何让DIV可编辑、可拖动示例代码
Sep 18 #Javascript
jQuery extend 的简单实例
Sep 18 #Javascript
Javascript中Event属性搜集整理
Sep 17 #Javascript
js获取html文件的思路及示例
Sep 17 #Javascript
JS的Document属性和方法小结
Sep 17 #Javascript
You might like
关于PHP中的Class的几点个人看法
2006/10/09 PHP
PHP如何编写易读的代码
2007/07/10 PHP
浅析Laravel5中队列的配置及使用
2016/08/04 PHP
浅谈PHP中的数据传输CURL
2016/09/06 PHP
PHP进程通信基础之信号量与共享内存通信
2017/02/19 PHP
菜鸟javascript基础资料整理2
2010/12/06 Javascript
JavaScript初学者应注意的七个细节小结
2012/01/30 Javascript
在ASP.NET中使用JavaScript脚本的方法
2013/11/12 Javascript
jQuery之选项卡的简单实现
2014/02/28 Javascript
用jquery的方法制作一个简单的导航栏
2014/06/23 Javascript
轻松创建nodejs服务器(10):处理上传图片
2014/12/18 NodeJs
JS基于面向对象实现的放烟花效果
2015/05/07 Javascript
JS实现从网页顶部掉下弹出层效果的方法
2015/08/06 Javascript
JavaScript中0和&quot;&quot;比较引发的问题
2016/05/26 Javascript
详解Vue2+Echarts实现多种图表数据可视化Dashboard(附源码)
2017/03/21 Javascript
AngularJS常见过滤器用法实例总结
2017/07/06 Javascript
VUE饿了么树形控件添加增删改功能的示例代码
2017/10/17 Javascript
Vue组件化开发思考
2018/02/02 Javascript
JavaScript对JSON数组简单排序操作示例
2019/01/31 Javascript
在vue中实现禁止屏幕滚动,禁止屏幕滑动
2020/07/22 Javascript
JavaScript实现拖动对话框效果的实现代码
2020/10/12 Javascript
Python实现身份证号码解析
2015/09/01 Python
VSCode下配置python调试运行环境的方法
2018/04/06 Python
python的格式化输出(format,%)实例详解
2018/06/01 Python
Python中list的交、并、差集获取方法示例
2019/08/01 Python
基于Django实现日志记录报错信息
2019/12/17 Python
基于OpenCV的网络实时视频流传输的实现
2020/11/15 Python
eDreams澳大利亚:预订机票、酒店和度假产品
2017/04/19 全球购物
什么是托管函数?托管函数有什么用?
2014/06/15 面试题
2014年端午节活动方案
2014/03/11 职场文书
房地产销售主管岗位职责
2015/02/13 职场文书
师德师风培训感言
2015/08/03 职场文书
学生会主席任命书
2015/09/21 职场文书
2016简历自荐信优秀范文
2016/01/29 职场文书
2016年大学生社区服务活动总结
2016/04/06 职场文书
windows server2012 R2下安装PaddleOCR服务的的详细步骤
2022/09/23 Servers