day08(ES5和String)

ES5和String


#### 一、 ES5严格模式

1)概念:除了正常运行模式,ECMAscript5添加了第二种运行模式:“严格模式”(strict mode)。顾名思义,这种模式是的Javascript在更严格的条件下运行。

2)严格模式的作用:

a.消除了JS语法的一些不合理、不严谨之处,减少一些怪异行为;

b.消除代码运行的一些不安全之处,保证代码运行的安全;

c.提高编译器效率,增加运行速度;

d.为未来新版本的JS做好铺垫

注意点:同样的代码,在“严格模式”中,可能会有不一样的运行结果,一些在“正常模式”下可以正常运行的语句,在“严格模式”下将不能运行,掌握这些内容,有助于更细致深入的理解JS,让你编程一个更好的程序员。

二、严格模式的调用
1、如何进入严格模式?
进入严格模式的标志,书写这一行语句 "use strict"
老的浏览器会把他当成一串普通的字符串,加以忽略

2、“严格模式”有两种调用方式,适用于不同的场合;
针对整个脚本文件:将 "use strict" 放在脚本文件的第一行,则整个脚本文件都将以“严格模式”运行,
如果这行语句不在第一行,则无效,整个脚本以“正常模式”运行。
如果不同模式的代码文件合并成一个文件,这一点需要特别注意。

针对单个函数:将 "use strict" 放在函数的第一行,则整个函数以“严格模式”运行。

脚本文件的变通写法:因为第一种调用方式不利于文件合并,所以更好的做法是,借用第二种方法,将整个脚本文件放在一个立即执行的匿名函数中

三、进入严格模式的变化
进入严格模式之后,需要进行哪些行为变更:

1.全局变量声明时,必须加关键字(var)
正常模式:a = 10;    console.log(a)    //10
严格模式:a = 10;    console.log(a)    //a is not defined

2.this无法指向全局对象
正常模式:function fn(){ console.log(this) }        //window
严格模式:function fn(){ console.log(this) }        //undefined

3.函数内不允许出现重名参数
正常模式:function fn( a,b,b ){ console.log(a,b) }
fn(1,2,3)        //1,3
严格模式:function fn( a,b,b ){ }
//报错:Duplicate parameter name not allowed in this context    在此上下文中不允许出现重复的参数名

4.arguments对象
4.1 arguments对象不允许被动态改变
正常模式:
function fn(a){
    a=20;
    console.log(a);                //20
    console.log(arguments[0]);     //20
}
fn(10);

严格模式:
function fn(a){
    a=20;
    console.log(a);                //20
    console.log(arguments[0]);     //10
}
fn(10);

5、不允许使用arguments.callee


6.新增的保留字:implementsinterfaceletpackageprivateprotectedpublicstaticyield

ES5新增数组方法:

1、indexOf(data,start)接收两个参数:要查找的项和(可选的)表示查找起点位置的索引 

2、forEach() 循环  对数组进行遍历循环,对数组中的每一项运行给定函数。这个方法没有返回值

3、map(callback) ; 会遍历当前数组,然后调用参数中的方法,返回当前方法的返回值。
map可以改变当前循环的值,返回一个新的被改变过值之后的数组(map需return),一般用来处理需要修改某一个数组的值。映射

4、filter() 遍历和过滤。返回符合条件的元素的数组。filter需要在循环的时候判断一下是true还是false,是true才会返回这个元素,前期用过filter进行数组去重。 
四、字符串
1、字符串的对象概念:

字符串就是一串字符,由双(单)引号括起来。字符串是 JavaScript 的一种基本的数据类型。字符串不能进行算术运算,只能进行“连接”运算。

JS中的任何数据类型都可以当作对象来看。所以string既是基本数据类型,又是对象。

2、字符串的创建
1, 直接使用字符串字面量去创建

   var str1 = “亲, 包邮哦!;

   alert(typeof str1);

2, 通过new创建字符串对象, 通过new创建的都为object类型

   var str2 = new String(“hello world!);

   alert(typeof str2);

3, 省略new, 这种方式创建的不是object类型, 而是string类型

   var str3 = String(“hello world”);  包装类

   alert(typeof str3);
3、字符串的属性和方法
1)length:获取字符串的长度。如:var len=strObj.length;

2)toLowerCase():将字符串中的字母转成全小写。如:strObj.toLowerCase();

3)toUpperCase():将字符串中的字母转成全大写。如:strObj.toUpperCase()4)charAt(index):返回指定下标位置的一个字符。如果没有找到,则返回空字符串; 参数是下标


5)indexOf:返回一个字符串在原始字符串中的索引值(查找顺序从左往右查找)。如果没有找到,则返回-1;

例子:判断用户输入的邮箱地址是否有@符号

6)lastIndexOf:在原始字符串中,从右往左查找。如果没有找到,则返回-18)substring():在原字符串,返回一个字符串;不取结束位置,不能给负值会转成0 

注点意:参数是下标 
9)split():将一个字符串切割成若干段,返回一个数组。也就是说将一个字符串转成数组;括号里面可以给空字符串, 会把字符串切割成几份
var res = str.split("");

10)slice():提取字符串的片断,并在新的字符串中返回被提取的部分;不包括结束位置。给负值时,可以返回倒数第几个
var res = str.slice(0, 3);

11)trim():移除字符串首尾空白;

12)concat():连接两个或多个字符串,返回连接后的字符串

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

14)substr()	从起始索引号提取字符串中指定数目的字符。参数1表示起始位置  、值2表示截取的项数

15)charAt() 方法可返回指定位置的字符。 

练习:


3、统计字符串的个数   
使用对象原理,遍历字符串,用字符为键
let obj = {};
for(let i = 0 ; i < str.length;i++){
	if(obj[str[i]]){
		obj[str[i]]++;
	}else{
		obj[str[i]] = 1
	}	
}

知识补充:

回调函数:如果把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指的函数时,我们就说这是回调函数。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阿駷

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

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

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

打赏作者

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

抵扣说明:

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

余额充值