JS不区分大小写匹配字符串高亮模拟浏览器Ctrl+F

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS不区分大小写匹配字符串高亮模拟浏览器Ctrl+F相关的知识,希望对你有一定的参考价值。

参考技术A 参数1:字符串或正则
参数2 :要替换的 字符串 或函数

函数里有三个参数,不明白的童鞋可以console.log在控制台查看
通过arguments来访问,我看完后顿时恍然大悟
这个需求是一个朋友问的我,有点挂不住老脸,居然没解决,

当时写的 toLocaleLowerCase 转换大小写, 但是这样无疑会更改页面原油的大写字母,不算实现需求,后经妹子委托她‘男友’ 我同学,写出另一种方法,问题得以解决,哈哈

这家伙是真滴6,我都没想到这种方法,惭愧惭愧,当时我想的是先把匹配的到的保存在变量,然后逐一赋值给texts,双层for循环太对了,
还有一种不知可行不可行,实现到一半,看到这种想到最上面的方法,果断弃之。(使用indexOf查找下标,whie循环全字段保存下标,然后循环数组下标值,使用splice前后加标签,包裹,不过,splice会改变原有数组,废了半天劲 无用功,这特么的就是我想到方法!!)

老子想静静。

以上两种方法都不失为好的解决办法,多写多想,加油加油!努力

Nginx 路径匹配规则

Nginx 路径匹配规则

Nginx路径匹配符号

  • = 表示精确匹配

  • ^~ 表示uri以某个常规字符串开头,大多情况下用来匹配url路径,nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。

  • ~ 正则匹配(区分大小写)

  • ~* 正则匹配(不区分大小写)

  • !~ 区分大小写不匹配

  • !~* 不区分大小写不匹配

  • / 任何请求都会匹配

 location [=|~|~*|^~] /uri/ { }
 

符号优先级

首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

示例

 location  = / {
   # 精确匹配 / ,主机名后面不能带任何字符串
  [ 规则 A ]
 }
 
 location / {
   # 因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求
   # 但是正则和最长字符串会优先匹配
  [ 规则 B ]
 }
 
 location /documents/ {
   # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
   # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
  [ 规则 C ]
 }
 
 location ~ /documents/Abc {
   # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
   # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
  [ 规则 D ]
 }
 
 location ^~ /images/ {
   # 匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条。
  [ 规则 E ]
 }
 
 location ~* \.(gif|jpg|jpeg)$ {
   # 匹配所有以 gif,jpg或jpeg 结尾的请求
   # 然而,所有请求 /images/ 下的图片会被 [规则 E] 处理,因为 ^~ 优先级更高
  [ 规则 F ]
 }
 
 location /images/ {
   # 字符匹配到 /images/,继续往下,会发现 ^~ 存在
  [ 规则 G ]
 }
 
 location /images/abc {
   # 最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在
  [ 规则 H ]
 }
 
 location ~ /images/abc/ {
   # 只有去掉 [规则 E] 才有效:先最长匹配 [规则 H] 开头的地址,继续往下搜索,匹配到这一条正则,采用
  [ 规则 I ]
 }
 
 

其他简单示例

 # 微信授权文件通用匹配规则
 location ~(MP_verify_)*\.(txt)$ {
     root   /usr/share/nginx/file;
 }
 

匹配MP_verify_.txt文件,中间任意字符,并在/usr/share/nginx/file目录中寻找对应文件

 # 静态文件工程配置
 location ^~ /static/ {
     root   /data/product/static;
     index  index.html index.htm;
 }
 

匹配/static开头路径,并在/data/product/static寻找对应文件

 # 静态文件配置
 location ~* \.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ {  
     root /data/product/static/;  
 }
 

配置proxy_pass时路径拼接规则

在nginx中配置proxy_pass时,如果是按照^~匹配路径时,要注意proxy_pass后的url最后的/

  • 当加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;

  • 如果没有/,则会把匹配的路径部分也给代理走

 server {
     listen 80;
     server_name test.xxx.com;
     
     location ^~ /abc {
         proxy_set_header    Host $host;
         proxy_set_header    X-Real-IP $remote_addr;
         proxy_pass http://127.0.0.1:8081/;
     }
 }
 
 server {
     listen 80;
     server_name test.xxx.com;
     
     location ^~ /abc {
         proxy_set_header    Host $host;
         proxy_set_header    X-Real-IP $remote_addr;
         proxy_pass http://127.0.0.1:8081;
     }
 }
 


以上是关于JS不区分大小写匹配字符串高亮模拟浏览器Ctrl+F的主要内容,如果未能解决你的问题,请参考以下文章

grep命令

怎么设置正则表达式不区分大小写

实现高亮搜索文字?

vim的2个高亮匹配函数

Nginx中的正则如何匹配数字

不区分大小写的部分匹配两个字符串的麻烦?