挑战:万能的slash! 判断js中“/”是正则、除号、注释?
很久以前在其它地方就探讨和关注过这个问题,但都没有满意的解答。 看了zjfeihu 的帖子: 《前端代码加亮插件(html,jss,css),支持即时加亮,运行代码》,再次提出这个比较经典的难题。 目前,DW,Eclipse,EditPlus都不能完全正确的高亮js正则. 似乎只有JS引擎才明白谁是谁的谁? 我们万能的斜线!符号中的奥特曼! 斜线的含义可能是以下之一: *1 字符串里面的普通字符 "//////////" *2 注释里面的普通内容 ; //........./............. *3 行注释标记的前两个斜线之一 //...... *4 除号 x = 6 / 3; 这里的除号可以换行,换行后很变态 *5 赋值运算符 x /= 2; 这里的除号可以换行,换行后很变态 *6 正则表达式的起始符 rgx = /........./; *7 正则表达式的结束符 rgx = /........./; *8 正则表达式里被反斜杠转义的斜线 rgx = /....\/...../; *9 正则表达式里[]里未被转义的斜线 rgx = /....[//]...../; *10 块注释的起始符 /*.........*/; *11 块注释的结束符 /*.........*/; 真是十项全能啊! 对于给定的一段js代码,怎么判断里面的斜线是哪一种情况呢? 最最难的,是判断: * 是否是正则表达式的起始符 * 是否是正则表达式的结束符 * 是否是换行的除号 因为`$~$%~@^%*#***^(省略若干原因500字) 这是做js代码语法加亮必需过的一道槛! var i =1, typeef =2; var a = typeef / 3 /i; 这里是除号,除号 var b = typeof / 3 /i; 这里是正则 var c = typeof / \/i \//i /*....//...*/ //..... 这里几个正斜线依次是:正则起、字符、字符、正则终、块注释起、字符、字符、块注释终、行注释标记 换行的除号很变态,很难判断 i=1,i=1 /2/i; 这里是除号,i 的结果为0.5 i=1,i=1; /2/i; 这里是正则,i 还是1 转义要考虑 字符串变量要考虑 注释要考虑 []里可转义也可不转义要考虑 换行的除号也很变态 javascript运算符里面,主要有5个是单词形式的: delete、instanceof、new、typeof、void 斜线可能紧接在这几个运算符后面,就像上面的例子 运算符要被当作加号减号一样处理,它与表达式要区别开来 还有一个赋值运算符 /= 是要考虑的 JS引擎解析的时候,是怎么处理这个逻辑的呢? 我都还没有想清楚,欢迎给力! |
挑战:万能的slash! 判断js中“/”是正则、除号、注释?的更多相关文章
- 判断js中的数据类型的几种方法
判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...
- 转:判断js中的数据类型的几种方法
判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...
- 如何判断js中的数据类型?
js六大数据类型:number.string.object.Boolean.null.undefined string: 由单引号或双引号来说明,如"string" number: ...
- 如何判断js中的数据类型
如何判断js中的数据类型:typeof.instanceof. constructor. prototype方法比较 如何判断js中的类型呢,先举几个例子: var a = "iamstri ...
- [转]如何判断js中的数据类型
原文地址:http://blog.sina.com.cn/s/blog_51048da70101grz6.html 如何判断js中的数据类型:typeof.instanceof. constructo ...
- 如何判断js中的数据类型(转)
如何判断js中的数据类型:typeof.instanceof. constructor. prototype方法比较 如何判断js中的类型呢,先举几个例子: var a = "iamstri ...
- 判断js中的数据类型
如何判断js中的数据类型:typeof.instanceof. constructor. prototype方法比较 如何判断js中的类型呢,先举几个例子: var a = "iamstri ...
- JS中的正则应用
如果还未掌握正则基础知识可先看另一篇:正则笔记-忘记就来看 创建方法: 直接量语法:/pattern/attributes 创建 RegExp 对象的语法:new RegExp(pattern, at ...
- js进阶js中支持正则的四个常用字符串函数(search march replace split)
js进阶js中支持正则的四个常用字符串函数(search march replace split) 一.总结 代码中详细四个函数的用法 search march replace split 二.js进 ...
随机推荐
- TSQLDBServerHttpApi一个使用HTTPS.SYS内核的数据库服务端控件
TSQLDBServerHttpApi一个使用HTTPS.SYS内核的数据库服务端控件 在WINDOWS操作系统,TSQLDBServerHttpApi使用HTTPS.SYS作为通信内核,而HTTPS ...
- VUE -- Vue.js每天必学之计算属性computed与$watch
在模板中绑定表达式是非常便利的,但是它们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么 Vue.js 将绑定表达式限制为一个表达式.如果需 ...
- golang之bufio包的使用
原文地址:http://www.niu12.com/article/38 github地址:https://github.com/ZQCard/go_api_practice // 参考:https: ...
- npm使用常见问题及注意事项
1.npm.cnpm.yarn不要混用,一个项目只使用一个 2.NPM problem: npm ERR! extraneous 表明安装了很多不需要的三方包 使用命令 npm prune删除无用的包 ...
- http://jingyan.baidu.com/article/dca1fa6fa07000f1a44052f6.html
http://jingyan.baidu.com/article/dca1fa6fa07000f1a44052f6.html
- MySQL5.6 怎样优化慢查询的SQL语句 -- SQL优化
上篇:MySQL5.6 怎样优化慢查询的SQL语句 -- 慢日志介绍 在实际的日志分析中,通常慢日志的log数量不少,同一时候同样的查询被记录的条数也会非常多.这里就须要怎样从慢日志查询中找到最有问题 ...
- Java调用Oracle存储过程
package com.hp.test; import java.sql.CallableStatement; import java.sql.Connection; import java.sql. ...
- Windows下启动Solr报错:Nothing to start,exiting...
如果用java -jar start.jar命令启动Solr时报错:Nothing to start,exiting...,可尝试: 百度jetty,上官网下载压缩包并解压(下载页面地址:http:/ ...
- RocketMQ性能压测分析(转)
原创文章,转载请注明出处:http://jameswxx.iteye.com/blog/2093785 一 机器部署 1.1 机器组成 1台nameserver 1台broker 异步刷盘 2 ...
- 使用网桥模式(bridge networking mode)配置KVM-QUME虚拟机网络
(1)linux要工作在网桥模式,所以必须安装两个RPM包.即:bridge-utils和tunctl.它们提供所需的brctl.tunctl命令行工具.能够使用yum在线安装: [root@serv ...