javascript字符串循环匹配实例分析
2015-07-17 00:00
886 查看
本文实例讲述了javascript字符串循环匹配的方法。分享给大家供大家参考。具体如下:
采用exec和String.match方法,对于exec必须开启全局匹配g标识才能获取所有匹配
// 需要提取这种数据 <td>2012-12-17</td><td>11:02 , 12:25 , 13:22 , 15:06 , 15:12 , 19:22 , 23:47</td> var rawData = '<table><th align="left" scope="col">日期</th><th align="left" scope="col">签到签退时间</th></tr><tr class="GridViewRowStyle" style="height:20px;">' + '<td>2012-12-03</td><td>10:16 , 13:22 , 20:05</td></tr><tr class="GridViewRowStyle" style="height:20px;">' + '<td>2012-12-04</td><td>11:16 , 14:22 , 21:05</td></tr><table>'; // 方法一 var regexp = /<td>(\d{4}-\d{2}-\d{2})<\/td><td>(.*?)<\/td>/g; // 加上g标识才会全局匹配,否则只匹配一个 var matchedArray = regexp.exec(rawData); while(matchedArray != null) { console.dir(matchedArray); matchedArray = regexp.exec(rawData); } // 方法二 var regexp = /<td>(\d{4}-\d{2}-\d{2})<\/td><td>(.*?)<\/td>/g; // 加上g标识才会全局匹配 var matchedArray = rawData.match(regexp); console.dir(matchedArray); // 方法三 var regexp = /<td>(\d{4}-\d{2}-\d{2})<\/td><td>(.*?)<\/td>/; // 不加g标识 var matchedArray = rawData.match(regexp); console.dir(matchedArray); console.log(matchedArray.index); while(matchedArray != null) { rawData = rawData.substr(matchedArray.index + matchedArray[0].length); matchedArray = rawData.match(regexp); } console.dir(matchedArray);
希望本文所述对大家的javascript程序设计有所帮助。
相关文章推荐
- 7月16日学习内容:把jsp页面转化为html页面
- 通过js动态清空、增加、删除、修改下拉框中的元素
- js获取json对象
- javaScript中Math对象的基本介绍
- JavaScript对象和数组
- 怎么在js里写html
- JS DOM编程艺术——显示缩略语列表—— JS学习笔记2015-7-16(第85天)
- JavaScript中判断数据类型
- JS笔记(执行环境,作用域)
- 《JavaScript设计模式与开发实践》读书笔记之命令模式
- js颜色拾取器
- js中动态加载js并且判断加载完成执行回调函数
- toString 方法
- javascript的typeof操作的返回值类型
- [javascript]一种兼容性比较好的简单拖拽
- 深入理解JavaScript系列(36):设计模式之中介者模式
- 深入理解JavaScript系列(37):设计模式之享元模式
- JavaScript数组
- 深入理解JavaScript系列(41):设计模式之模板方法
- 深入理解JavaScript系列(46):代码复用模式(推荐篇)