闭包

.闭包:函数在调用的时候会形成一个私有的作用域,对内部变量起到保护的作用,这就是闭包。

2.变量销毁:

1.人为销毁  var a=12; a=null

2.自然销毁  函数调用完成之后 浏览器会自动销毁函数内的变量

 

3闭包作用

  1. 保护变量
  2. 缓存数据

4.闭包的种类

1.函数式

 

2.对象式

 

5.函数返回值的问题

每个函数都有一个返回值,如果人为返回,return的什么就是什么,如果没有就是undefined

 

6.闭包怎么缓存数据

 

 

 

 

 

 

7. 正则regexp

正则 就是一条规则,用于检验字符串的格式,目标就是字符串。

只要要是表单提交的数据都是字符串。

8. 正则定义

  1. var reg=new RegExp();
  2. Var reg=/格式/;

9. 正则的方法

就两大功能,一个是匹配,匹配成功就是true,第二个是捕获,如果有就拿出来。

Test() 用于匹配

Exec()用于捕获

10. 正则修饰符  如何去匹配

  1. 区不区分大小写  i  代表忽略大小写
  2. 全局     g代表全局匹配
  3. M代表多行匹配

怎么使用

  1. var reg=new RegExp(“hello”,g)
  2. Var reg=/hello/gi

 

11.字符串的方法 跟正则有关的

1.match()查找一个或多个与正则相匹配的 有就返回的是查找的结果,没有就是null

 

2.search() 匹配和正则相同的字符,有就返回索引,没有就是-1

 

  1. replace()匹配与正则相同的,并替换掉,返回的是替换后的字符串

 

12,正则的方括号

[abc] 代表查找方括号中的任何字符

[^abc]代表查找任何一个不在方括号之间的字符

[0-9]查找0到9之间的数字

[a-z] 查找任何小写a到小写z的字符

[A-Z]查找任何大写A到大写Z的字符

[A-z]查找大写A到小写z的字符

(red|blue|green)

13元字符

.代表单个字符

w代表单词字符  数字 字母 _

W 代表非单词字符

d 代表数字

D 代表非数字

s 代表空白字符

S 代表非空白字符

 代表单词边界

B 代表非单词边界

14. 量词

  1. n+ 代表至少1个n的字符
  2. n* 代表0个或多个n
  3. n? 包含0个或1个n
  4. N{x} 包含x个n
  5. N{x,} 包含至少x个n
  6. N{x,y} 包含大于等于x个小于等于y个n
  7. N$  包含以n结尾的字符串
  8. ^n包含以n开头的字符串

9,?=n 指定字符串后面紧跟的n的字符串

--

正则RegExp

概念:用来检验字符串的规则。

如何使用

Var reg=//  var reg=new RegExp() 最后的本质都是一个对象

方法

Test() 匹配的方法

Exec()捕获的方法

修饰符

img

方括号

[]

元字符d

量词

 

正则的理解

  1. 正则的懒惰性

每一次在exec()中捕获的时候,只捕获第一次匹配的内容,而不往下捕获了。我们把这叫正则的懒惰性,每一次捕获的开始位置都是从0开始

 

解决正则的懒惰性呢

修饰符g

正则的实例对象reg上有一个lastIndex属性 他是正则捕获的起始位置

 

  1. 正则的贪婪性

每一次匹配都是按照最长的出结果,我们把这种功能叫正则的贪婪性

 

如何解决正则的贪婪性

在元字符量词后面加?

 

补充 循环语句  for   for  in  while   do---while---

 

二 分组捕获 正则带()  在数分组的个数时从左往右

var reg=/(a)(b)/ 就相当于大正则里面带了两个小正则

第一组是(a) 第二组是(b)

分组捕获的作用

  1. 改变优先级
  2. 分组引用  1,2

2代表和第二个分组出现一模一样的内容,1代表和第一个分组出现一模一样的内容

 

Reg中的规则是第一个是一个分组 且是一个单词字符 第二个是个分组引用要求和第一组一模一样,第三个是第二个分组且是一个单词字符,第四个是一个分组引用,要求和第二组一模一样。

3.分组捕获

分组的捕获前提是正则存在分组,不仅把大正则的内容捕获到,把小正则的内容也捕获到。

 

怎样解除分组中分组捕获呢,如果你不想捕获某一个分组中的内容,在这个分组的前面加上?:就可以了

 

 

原文地址:https://www.cnblogs.com/jiaxinchao/p/10154166.html