JavaScript函数,正则表达式

本文详细探讨了JavaScript中的函数,包括函数的声明、参数、返回值、立即执行函数及其用法。此外,还讲解了JavaScript正则表达式的基础知识,如规则、量词、元字符,并给出了实例应用,帮助读者掌握如何在JavaScript中有效地使用函数和正则表达式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JavaScript函数,正则表达式


一.函数function

    函数也是一个对象

    函数中可以封装一些功能(代码),在需要的使用可以执行这些功能(代码)

    函数中可以保存一些代码在需要的时候调用

    使用typeof检查一个函数对象时,会返回function

 

使用函数声明来创建一个函数(建议使用方式)

语法:function 函数名([形参1,形参2,...,形参N]){

               语句

   }

说明:[形参1,形参2,...,形参N]这里的[]表示可以使用参数也可以不使用参数

函数的调用:函数名([实参1,实参2,...]);

例如:function fun2(){

           console.log("123");

  }

   fun2();

匿名函数

例如:function(){

 

  }

二.JavaScript函数的参数

1.调用函数时解析器不会检查实参的类型,所以要注意,是否有可能会接收到非法的参数,如果有可能则需要对参数进行类型的检查

2.调用函数时,解析器也不会对检查实参的数量多余的参数将不会被赋值,如果实参少于形参的数据,则没有对应实参的形参将是undefined

例如:function result(a,b,c){

             console.log("a="+a);

             console.log("b="+b);

             console.log("c="+c);

             var sum=a+b+c;

            console.log("sum="+sum);

}

  result(123,234);//实参少于形参

  result(123,234,345,6767,78,9);//实参多余形参

 

function sum(a,b){

       var add=a+b;

       console.log(add);

}

sum(123,456);-->123+456=579;

sum(false,123);;-->false+123=124;

 

三.函数的返回值:

可以通过return 来返回函数的返回值

  语法:return 值;

  return 后面值将会作为函数的执行结果返回,

  可以定义一个变量来接收函数的返回值

  在函数return后的语句都不会执行

  如果return语句后不跟任何值,就相当于返回一个undefined

例如:function sum(a,b){

               var c=a+b;

               return c;

               alert("234,234");

  }

  Var  total = sum(12,45);

  console.log("返回结果=="+total);-->57

 

四.立即执行函数

函数定义完,立即被调用,这种函数叫做立即执行函数

立即执行函数往往只会执行一次

模板:(function(){

     alert("这是一个立即执行函数");

})();

 

 例如:  (function(a,b){

                      alert(a+b);

        })(23,23);

五.函数的方法

函数也可以作为对象的属性,如果一个函数作为一个对象的属性保存,那么我们称这个函数是这个对象的方法。调用函数就所调用对象的方法,但是它只是名称上的区别没有其他的区别。

例如:function sayHello(){

                    alert("hello every!");

          }

   var obj1=new Object();

   obj1.name="小红";

   obj1.age=23;

   obj1.sayWorld=sayHello;

通过对象字面量的方式创建对象

var person={

                name:"小明",

               age:12,

sayWord:function(){

                alert("hello every! my name is "+person.name);

         }

};

       person.sayWord();

 

六.枚举对象中的属性

使用for ... in 语句

 for in 语法

for(var 变量 in 对象){

      语句

}

例如:for(var item in person){

            console.log(item);

            console.log(person[item]);

            console.log("属性名="+item+",属性值="+person[item]);

            console.log("属性名="+item+",属性值="+person[item]);

}

 

七.JavaScript正则表达式

正则表达式:又称规则表达式

英文名为Regular Expression,在代码中常简写为regex、RegExp或RE

 

正则表达式用于定义一些字符串的规则,计算机可以根据正则表达式,来检查一个字符串是否符合规则,可以将字符中符合规则的内容提取出来

 

手机号的规则:

首先 18813549655(11位数字)

1.以1开头

2.第二位(3-9)

3.第三位以后任意9个数字

 

语法: var 变量=new RegExp("正则表达式","匹配模式");

使用typeof检查正则对象,则会返回object(对象)

var reg=new RegExp("a"); 这个表达式可以用来检查一个字符串中是否含有字符a

在构造函数中可以传递一个匹配模式作为第二个参数

i 忽略大小写

g 全局匹配

 

正则表达式的方法:

test()

 使用这个方法可以用来检查一个字符串中是否符合正则表达式的规则

如果符合则返回true,否则返回false

 

 

使用字面量来创建正则表达式

语法: var 变量=/正则表达式/匹配模式

 

 使用字面量的方法创建更加简单

 使用构造函数创建更加灵活

 

[] 使用中括号表示范围

[abc] 等价于 a|b|c

[a-z] 表示匹配所有的小写字母

[A-Z] 表示匹配所有的大写字母

[A-z] 表示匹配所有的字母(包含大小写)

  [0-9] 表示匹配所有的数字

 

八.JavaScript字符串与正则表达式相关的方法

 支持正则表达式的String对象的方法

search()  - 检索与正则表达式相匹配的值。

match()   - 找到一个或多个正则表达式的匹配。

replace() - 替换与正则表达式匹配的子串。

split()   - 把字符串分割为字符串数组。

 

1.split()

 把字符串分割为字符串数组。

 该方法可以传递一个正则表达式作为参数,这样方法将会根据正则表达式去拆分

 该方法即使不指定全局匹配,也会全部拆分字符串

 

2.search()  

 可以搜索字符串中是否含有指定内容

 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到到返回-1

 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串

 serach() 只会查找第一个,即使设置全局匹配也没用

 

3.macth()

 可以根据正则表达式,从一个字符串中将符合条件的内容提取出来

 默认情况下我们的macth只会找到第一个符合要求的内容,找到以后就停止检索

我们可以设置正则表达式为全局匹配模式,这样就会匹配到所有的内容

可以为一个正则表达式设置多个匹配模式,且顺序无所谓

 match()会将匹配到的内容封装到一个数组中返回,即使只查询到一个结果

 

4.replace()

 可以将字符串中指定内容替换为新的内容

 参数说明:

1.被替换的内容

2.新的内容

 

九.JavaScript正则表达式语法(量词)

量词:

 通过量词可以设置一个内容出现的次数

 量词只对它前面一个内容起作用

 {n} 出现n次

 {m,n} 出现m次到n次

 {n,} 出现n次以上

 + 至少出现一次

 * 出现零次或则零次以上

 ? 出现一次或则零次

 

检查一个字符串中是否以a开头

^ 表示开头   

$ 表示结尾

 

创建一个正则表达式,用来检查一个字符串是否是一个合法手机号

 

手机号的规则:

 18813549655(11位)

1.以1开头

2.第二位(3-9)

3.第三位以后任意9个数字

 

十.JavaScript正则表达式语法(元字符)

检查一个字符串中是否含有"."

"."表示匹配任意字符

在正则表达式中\反斜杠 作为转义字符

若想要匹配字符"."正则表达式为 \.

\\ 表示匹配一个反斜杠\

 

 .  表示匹配任意字符

  \w 匹配任意字母、数字、"_" 下划线==>[A-z0-9_]

  \W 匹配除了字母、数字、"_" 下划线==>[^A-z0-9_]

  \d 匹配数字[0-9]

  \D 除了数字[^0-9]的任意字符

  \s 匹配空格

  \S 匹配除了空格的任意字符

  \b 匹配单词边界

  \B 匹配非单词边界。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

可乐沙司

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值