1:ES5简介
ECMAScript 5.1 (或仅 ES5) 是ECMAScript(基于JavaScript的规范)标准的修正。 与HTML5规范进程本质类似,ES5通过对现有JavaScript方法添加语句和原生ECMAScript对象做合并实现标准化。
2:严格模式简介
除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict mode)。顾名思义,这种模式使得Javascript在更严格的条件下运行。
设立"严格模式"的目的,主要有以下几个:
(1):消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为。
(2):消除代码运行的一些不安全之处,保证代码运行的安全。
(3):提高编译器效率,增加运行速度。
(4):为未来新版本的Javascript做好铺垫。
"严格模式"体现了Javascript更合理、更安全、更严谨的发展方向,包括IE 10在内的主流浏览器,都已经支持它,许多大项目已经开始全面拥抱它。
正常运行模式:
a = 4;
alert(a); // 4
// 严格模式:
"use strict"
a = 4;
alert(a); // 报错 因为a还没有定义
3:进入严格模式
进入“严格模式”的标志,书写这行语句:"use strict";
老版本的浏览器会把它当作一行普通字符串,加以忽略。
4:如何调用严格模式
"严格模式"有两种调用方法,适用于不同的场合。
针对整个脚本文件:将"use strict"放在脚本文件的第一行,则整个脚本都将以"严格模式"运行。若这行语句不在第一行,则无效,整个脚本以"正常模式"运行。如果不同模式的代码文件合并成一个文件,这一点需要特别注意。
针对单个函数:将"use strict"放在函数的第一行,则整个函数以"严格模式"运行。
// Eg
function aaa() {
'use strict';
b = 6;
b++;
alert(b);
}
(3)脚本文件的变通写法:因为第一种调用方法不利于文件合并,所以更好的做法是,借用第二种方法,将整个脚本文件放在一个立即执行的匿名函数之中。
// Eg:第一个:
'use strict';
b = 6;
b++;
alert(b); // 7
// Eg:第二个:
var a = 4;
a++;
// Eg:和并:
(function () {
'use strict';
var a = 4;
a++;
})();
(function () {
b = 6;
b++;
})();
5:严格模式改变语法和行为
严格模式对Javascript的语法和行为,都做了一些改变。
(1):全局变量显式声明。
在正常模式中,如果一个变量没有声明就赋值,默认是全局变量。严格模式禁止这种用法,全局变量必须显式声明。因此,严格模式下,变量都必须先用var命令声明,然后再使用。
// Eg:
a = 4;
alert(a); // 4
// 严格模式:
"use strict"
a = 4;
alert(a); // 报错 因为a还没有定义
(2):函数形参不允许重复。
function sum(a, a, b) {
console.log(a, b);
}
sum(4, 7); // 7 undefined
'use strict';
function sum(a, a, b) {
console.log(a, b);
}
sum(4, 7); // 报错
(3):禁止使用with语句。
with(document) {
alert(1);
} //1
'use strict';
with(document) {
alert(1);
} // 报错
(4):禁止函数内部this关键字指向全局对象,this指向undefined。
(5):函数必须声明在顶层。
将来Javascript的新版本会引入“块级作用域"。为了与新版本接轨,严格模式只允许在全局作用域或函数作用域的顶层声明函数。也就是说,不允许在非函数的代码块内声明函数。
if(1) {
function a(){}
} else {
function a() {}
} //错误 ( if语句里不能声明函数)
正确写法:
function a() {
if(true) {
alert('你好');
} else {
alert('不好');
}
}
a();
6:ES5新增函数方法
注:新增方法IE6/7/8均不支持。
讲解this变量的两种使用场景。
this的使用
(1):在全局环境中或者普通函数中,this指向的是window对象
'use strict';
console.log(this); // window
function hello() {
console.log(this);
}
hello( ); //window
(2):在对象的方法中,this指向的是方法的拥有者(对象)
var obj = {
say: function () {
console.log(this);
}
};
obj.say( ); //obj
1:bind方法:改变了函数内部上下文的this。返回值是函数。在调用返回函数时,传入的实参是在bind中传入参数的基础上往后排的。
![](https://img-blog.csdnimg.cn/img_convert/d3fd56dd0999bda8566dbd51ea54e2fc.png)
bind:改变函数内部this的指向,返回值是一个内部this已经发生改变的新的函数
// (1)
function sum(a, b) {
console.log(this);
console.log(a + b);
}
sum(1,2) // Windows 3
// (2)
function sum(a, b) {
console.log(this);
console.log(a + b);
}
var newSum = sum.bind('aaa');
newSum(1,2); // string{“aaa”} 3
// (3)在调用返回函数时,传入的实参是在bind中传入参数的基础上往后排的
function sum(a, b) {
console.log(this);
console.log(a + b);
console.log(arguments);
}
var newSum = sum.bind('aaa', 6);
newSum(3, 4); // string{“aaa”} 9 [ 6,3,4 ]
7:ES5新增数组方法
(1):forEach方法:遍历数组。第二个参数为可选的上下文参数(改变this指向)。
语法:
arr.forEach( function (v, k, arr) { } );
注:参数是回调函数
![](https://img-blog.csdnimg.cn/img_convert/05382a926d75aff603099318b2fbdfb6.png)
![](https://img-blog.csdnimg.cn/img_convert/8abbce2f909b8f320a082675153a895d.png)
forEach方法中的function回调支持3个参数,第1个是遍历的数组内容;第2个是对应的数组索引,第3个是数组本身。forEach不会遍历空位置的内容。如:[1, , 3],只会遍历1和3。
1)回调函数传三个值
// Eg:
var arr = [4,7,9,10,12] ;
arr.forEach(function (v,k,arr ) {
console.log(v,k,arr);
});
// 4 0 [4,7,9,10,12] 7 1 [4,7,9,10,12] 9 2 [4,7,9,10,12] 10 3 [4,7,9,10,12] 12 4 [4,7,9,10,12]
2)回调函数传两个参数
// Eg:
var arr = [4,7,9,10,12] ;
arr.forEach(function (v,k) {
console.log(v,k);
console.log(this)
});
// 4 0 7 1 9 2 10 3 12 4 windows
3)forEach传第二个参数,用来改变回调函数this的指向
// Eg:
var arr = [4,7,9,10,12] ;
arr.forEach(function (v,k) {
console.log(this) // Number {111}
},111);
(2):map方法:将数组映射成新数组。回调函数需要有返回值。
![](https://img-blog.csdnimg.cn/img_convert/3270ae327a3c484fcfc6173c6964dda6.png)
![](https://img-blog.csdnimg.cn/img_convert/584dcda36c3045dbebe12d3f816b297a.png)
// Eg:
var arr = [4,7,9,10,12] ;
arr.map(function (v,k,arr ) {
console.log(v,k,arr);
});
// 4 0 [4,7,9,10,12] 7 1 [4,7,9,10,12] 9 2 [4,7,9,10,12] 10 3 [4,7,9,10,12] 12 4 [4,7,9,10,12]
注:与forEachde 区别是可以返回一个全新的数组,需要返回值
// Eg:
var arr = [4,7,9,10,12] ;
var newArr = arr.map(function (v,k,arr ) {
console.log(v,k,arr);
return v*k ;
});
console.log(newArr); // [ 0 7 18 30 48]
(3):filter方法:指数组过滤后,返回过滤后的新数组。 filter的callback函数需要返回布尔值true或false。
![](https://img-blog.csdnimg.cn/img_convert/90d7135525234d8492b69f0c0429c4f0.png)
判断为true就返回该值 否则不返回
// Eg :
var arr = [4,6,7,9,10,13];
var newArr = arr.filter(function (v) {
if(v >= 8){
return ture;
}else{
return false;
}
})
console.log(newArr); // [9,10,13]
(4):some方法:指是否“某些项”合乎条件。返回布尔值。只要数组中有一项符合条件,则返回true。
![](https://img-blog.csdnimg.cn/img_convert/98020a91199115a7a6465dccde2c59bf.png)
![](https://img-blog.csdnimg.cn/img_convert/06e4c2e37b4eed58110cc8129b648785.png)
// Eg :
var arr = [1,4,7,9];
var newArr = arr.somer(function (v) {
if(v >5){
return ture;
}else{
return false;
}
})
console.log(newArr); // true
(5):every方法:所有项都必须合乎条件。返回布尔值。
语法:array.every(callback, [ thisobject]); 必须每一项都要符合条件,否则返回false。
![](https://img-blog.csdnimg.cn/img_convert/ebceda5e785f2c212d2e19398f6c8d26.png)
// Eg :
var arr = [1,4,7,9];
var newArr = arr.somer(function (v) {
if(v >5){
return ture;
}else{
return false;
}
})
console.log(newArr); // false
(6):indexOf方法:返回整数索引值,如果没有匹配(严格匹配),返回-1。 fromIndex可选,表示从这个位置开始搜索,若缺省或格式不合要求,使用默认值0。
去数组里找一个元素,如果存在则返回下标,如果不存在,则返回-1
![](https://img-blog.csdnimg.cn/img_convert/597ec2b9138e63754f325de76c91c8b2.png)
// Eg:
var arr = [1,4,7,4 ,9];
var index = arr.indexOf(5);
console.log(index); // -1
// Eg:
var arr = [1,4,7,9];
var index = arr.indexOf(4);
console.log(index); // 1
还可以指定第二个参数,表示在哪个位置开始找
// Eg:
var arr = [1,4,7,9,4,6];
var index = arr.indexOf(4,2);
console.log(index); // 4
查找所有的4:
var startIndex = 0;
while( (index=arr.indexOf(4,startIndex)) !=-1){
console.log(index); // 1 4
startIndex = index +1;
}
(7):lastIndexOf方法:从数组的末尾开始查找,而不是从开头。还有一个不同就是fromIndex的默认值是array.length - 1而不是0。
![](https://img-blog.csdnimg.cn/img_convert/b2090705a82dd6dbd30a1135cc6f080e.png)
// Eg:
var arr = [1,4,7,9,4,6];
console.log( arr.lastIndexOf (4)); //4
// Eg:
var arr = [1,4,7,9,4,6];
console.log( arr.lastIndexOf (4,3)); //1
(8):reduce方法:归并。递归减少。
callback函数接受4个参数:之前值、当前值、索引值以及数组本身。initialValue参数可选,表示初始值。若指定,则当作最初使用的previous值;如果缺省,则使用数组的第一个元素作为previous初始值,同时current往后排一位,相比有initialValue值少一次迭代。
语法:
reduce(function (prev, current, index, arr) { })
![](https://img-blog.csdnimg.cn/img_convert/8250082882c6b118e0a5b37a19d0f800.png)
案例:
![](https://img-blog.csdnimg.cn/img_convert/747b6247664bb8ef1f6f48e5393c1f6d.png)
解析:
![](https://img-blog.csdnimg.cn/img_convert/ec3f15e5a1031f45390d10f073913d0b.png)
说明:
1:因为initialValue不存在,因此一开始的previous值等于数组的第一个元素。
2:从而current值在第一次调用的时候就是2。
3:最后两个参数为索引值index以及数组本身array。
// Eg:
var arr = [1,4,7,9]
arr.reduce(function (prev, current, index, arr) {
console.log(prev, current, index, arr);
})
// 1 4 1 [1,4,7,9] undefined 7 2 [1,4,7,9] undefined 9 3 [1,4,7,9]
因为函数没有加return 所以为undefined
// Eg:
var arr = [1,4,7,9]
arr. reduce(function (prev, current, index, arr) {
console.log(prev, current, index, arr);
return current;
})
// 1 4 1 [1,4,7,9] 4 7 2 [1,4,7,9] 7 9 3 [1,4,7,9]
Reduce可以传第二天参数,指定初始化的先前值
// Eg:
var arr = [1,4,7,9]
arr. reduce ( function (prev, current, index, arr) {
console.log(prev, current, index, arr);
return current;
},100)
// 100 1 0 [1,4,7,9] 1 4 1 [1,4,7,9] 4 7 2 [1,4,7,9] 7 9 3 [1,4,7,9]
应用:求【1,4,7,9】的和
// Eg:
var arr = [1,4,7,9]
var sum = arr. reduce ( function (prev, current, index, arr) {
return prev + current ;
})
console.log(sum); // 21 ( 1 4 —— 5 7—— 12 9)
(9):reduceRight方法:和reduce用法类似,实现上差异在于reduceRight是从数组的末尾开始实现。
![](https://img-blog.csdnimg.cn/img_convert/c9384e2abddcb435d2b7bff6c567f4ea.png)
案例:
![](https://img-blog.csdnimg.cn/img_convert/4108248eed1544d0e7929e4e491be7c5.png)
说明:
![](https://img-blog.csdnimg.cn/img_convert/23117a54df721048d2286d4cec9da1e0.png)
(10):Array.isArray():判断一个变量是否为数组。
用typeof去查看一个变量是不是数组或对象是不靠谱的,因为都是object
// Eg:
var arr = [];
console.log(Array.isAarray(arr)) ; // true
8:ES5新增字符串方法
(1):trim方法:去除字符串首尾的空白字符。
![](https://img-blog.csdnimg.cn/img_convert/61ca8e46057ab0645085f45514da30b0.png)
// Eg:
var str ='123 456';
console.log(str.trim()); // 123 456 (字符里面的空格会保留)
9:ES5新增JSON对象方法
Json是一种传输数据的格式(以对象为样板,本质上就是对象,但用途有区别,对象就是本地用的,json是用来传输的)
(1):JSON.parse:将一个JSON格式的字符串转换成对象。
var str ='{ "name": "张三", "age": 28}';
console.log ( JSON.parse( str ) ); // { nam”:”张三”,age : 28}
// str =’{ ”name”: ”张三”, "age": 28}‘里面的必须都用双引号括起来,
不然会报错,单引号都不行,but像age本来就是数字类型 所以不用加
转成对象之后就可以通过 . 的形式访问
(2):JSON.stringify:将对象转换成JSON格式的字符串。
var obj = { name: '张三', "age": 28, 'introduce': function () {} };
console.log ( JSON.stringify( obj ) ); // {“name”:”张三”,”age”:28 } 函数不会保留
扩展:怎么将字符串"false"转换成布尔值false
console.log(JSON.parse("false")); // false
应用:
1:预习下午的字符串。
2:背诵记忆ES5。
1:字符串
JS中的任何数据类型都可以当作对象来看。所以string既是基本数据类型,又是对象。
字符串中的每个字符都有一个索引(相当于下标),索引以 0 开始
2:声明字符串
var sStr = ‘字符串’;
是字符串类型的
(2)通过构造函数:
var oStr = new String(‘字符串’);
是对象
注:通过构造函数创建的都是对象类型的
3:字符串属性
1.length
计算字符串的长度(不区分中英文,空格也算)。
// Eg:
var str = 'hello world!' ;
console.log(str.length); // 12
2.constructor
对象的构造函数。
// Eg:
var str = 'hello world!' ;
console.log(str.constructor) //String ( ) { };
4:字符串方法
1.myStr.charAt(num)
返回在指定位置的字符。即根据索引得到字符串中的某一个字符
var ss ="abc0123def&#*";
consoe.log( ss.charAt( 0) ; // a
consoe.log( ss.charAt( ss.lengtn - 1) ) ; // *
consoe.log( ss.charAt( -1) ; // 什么都没, 因为索引不存在
2.myStr.charCodeAt(num)
返回索引对应的字符的Unicode(是字符编码的一种模式)编码。
var ss ="abc0123def&#*";
consoe.log( ss.charCodeAt( 3 ) ; // 48
应用:打印字符串中的每个字符以及字符对应的编码
var str ="abcdefg 0123456789 ABCDEFGH 中国你好!";
for (var i = 0; i<s.length; i++){
doument.write ("下标为"+ i +"的字符串是:"+s.charAt( i ) +'<br/>"+"该字符的编码是"+s.charCodeAt ( i )+"<br />")
}
String.fromCharCode()
根据字符码生成字符串
String的意思就是不能用自己定义的字符串名字来调用,例如定义一个变量字符串 var str="";只能用String来定义调用。接受一个或多个指定的Unicode值,然后返回一个或多个字符串。(把unicode编码转换为字符串)。
// Eg:
var str = String.fromCharCode (97,65,48,20320);
console.log( str) ; // a A 0 你
4.myStr.indexOf()
返回某个指定的字符串,在字符串中首次出现的位置。如果要检索的字符串值没有出现,则该方法返回 -1。第二个参数指定开始查找的起始位置。
// Eg:
ss ="*aweotttwiotttlkdjfttt";
var index = ss.indexOf ("ttt")
console.log( index) ; // 5
5.myStr.lastIndexOf()
返回一个指定的字符串值最后出现的位置,如果要检索的字符串值没有出现,则该方法返回 -1。第二个参数指定开始查找的起始位置,只能指定正数。
// Eg:
var str = 'hello world!';
console.log(str.lastIndexOf( 'l' )); //9
console.log(str.lastIndexOf('l', 8)); // 3
6.myStr.match()
返回字符串中第一个和他匹配的字符串,返回的值是数组。如果匹配不到返回null。配合正则来用。
// Eg:
var str = 'hello world!';
console.log(str.match('ll'));
7.myStr.search()
返回出现的位置,查找不到返回-1。配合正则来用。
字符串中搜索到的第一个匹配的字符串的起始位置
// Eg:
var str = 'hello world!';
console.log(str.search('ll')); // 2
console.log(str.search('lle')); // -1
8.myStr.replace(“需替换的字符串”,“替换后的字符串”)
将字符串中的一些字符替换为另外一些字符。配合正则使用。
// Eg:
var str = 'hello world!'
console.log(str.replace('ll', 'LL'));
传回调函数
// Eg:
console.log(str.replace('ll', function (val) {
console.log(val);
return val.toUpperCase();
}));
9.myStr.slice(start,end)
从指定的开始位置,到结束位置(不包括结束位置)的所有字符串。如果不指定结束位置,则从指定的开始位置,取到结尾。注意的是,myStr.slice() 与 myArr.slice() 相似。
// Eg:
var str = 'abcefghijklmn';
console.log(str.slice(3, 6)); // efg
console.log(str.slice(3)); //efghijklmn
console.log(str.slice( )); // abcefghijklmn
console.log(str.slice(-5, -2)); // jkl
10.myStr.substring(start,end)
从指定的开始位置,到结束位置(不包括)的所有字符串。如果不指定结束位置,则从指定的开始位置,取到结尾。
// Eg:
var str = 'abcefghijklmn';
console.log(str.substring(4, 7)); // fgh
console.log(str.substring(-5, -2)); //不会报错 会把负数转换成0,从0位置开始截取到0(不包括0) 所以是空
// 区别:slice允许传负值,substring不允许
11.substr(start,length) (了解)
从指定的位置开始取指定长度的字符串。如果没有指定长度,从指定开始的位置取到结尾。 ECMAscript 没有对该方法进行标准化,因此反对使用它。
如果substr的start指定为负数,则该参数声明从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。
slice(start,end) vs substring(start,end)
slice参数可以是负数,如果是负数,从-1开始指的是字符串结尾。
substring参数是负数的时候,会自动转换为0。
12.split("分割位置",[指定的长度])
将一个字符串分割成数组。
// Eg:
var str = '?a=b&c=d&e=f';
str = str.slice(1); // a=b&c=d&e=f
var arr = str.split('&'); // [“a = b”,“c = d”,“e = f”]
arr.forEach( function (v) {
console.log(v.split('='));
});
console.log(arr) ; //
13.toLowerCase()
用于把字符串转换为小写。
14.toUpperCase()
将字符串转换为大写。
// Eg:
console.log('HAHA'.toLowerCase()); // haha
5:ASCII码和字符集
ASCII:American Standard Code for Information Interchange,美国信息交换标准代码。
![](https://img-blog.csdnimg.cn/img_convert/5976242b066b1f721be1781ac8024380.jpeg)
Unicode编码:
Unicode(统一码、万国码、单一码)是计算机科学领域里的一项业界标准,包括字符集、编码方案等。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。 Unicode目前普遍采用的是UCS-2,它用两个字节来编码一个字符。
如汉字"经"的编码是0x7ECF,注意字符码一般用十六进制来 表示,为了与十进制区分,十六进制以0x开头,0x7ECF转换成十进制 就是32463,UCS-2用两个字节来编码字符,两个字节就是16位二进制, 2的16次方等于65536,所以UCS-2最多能编码65536个字符。
GBK编码:
GBK全称《汉字内码扩展规范》(GBK即“国标”、“扩展”汉语拼音的第一个字母,英文名称:Chinese Internal Code Specification)。GBK 向下与GB2312编码兼容,向上支持 ISO 10646.1国际标准,是前者向后者过渡过程中的一个承上启下的产物。
UTF-8编码:
UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。 UTF-8用1到4个字节编码UNICODE字符。用在网页上可以同一页面显示中文简体繁体及其它语言(如英文,日文,韩文)。
应用:
敏感词过滤。
2.密码格式要求。
3.留言过滤。
![](https://img-blog.csdnimg.cn/img_convert/605000429cd4338de6d70648f284503d.png)
<style type="text/css">
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
#box {
margin: 30px auto;
padding: 10px;
width: 800px;
background: #eee;
}
ul {
list-style: none;
font-size: 12px;
}
#message {
width: 100%;
outline: none;
border: 1px solid #ccc;
resize: none;
}
#btn {
width: 80px;
height: 40px;
background: #ccc;
border: none;
outline: none;
cursor: pointer;
}
#btn:hover {
color: purple;
background: pink;
}
#list {
margin-top: 10px;
padding: 10px;
background: #fff;
}
#list li {
padding: 10px 4px;
border-bottom: 1px dashed #eee;
}
</style>
<body>
<div id="box">
<textarea name="" id="message" cols="30" rows="10"></textarea>
<input type="submit" value="提交" id="btn">
<ul id="list">
<li>这是第1条</li>
<li>这是第2条</li>
<li>这是第3条</li>
<li>这是第4条</li>
<li>这是第5条</li>
<li>这是第6条</li>
<li>这是第7条</li>
<li>这是第8条</li>
</ul>
</div>
<script type="text/javascript">
function $(id) {
return document.getElementById(id);
}
var btn = $('btn'), msg = $('message'), list = $('list');
// 敏感词
var sensitiveWords = ['你好', '好不好', '不好'];
btn.onclick = function () {
var val = msg.value;
// 判断用户有没有输入内容
if(val === '') {
alert('请输入留言!');
return false;
}
// 替换敏感词
sensitiveWords.forEach(function (v) {
while(val.indexOf(v) !== -1) {
val = val.replace(v, '***');
}
});
// 替换换行符
while(val.indexOf('\n') !== -1) {
val = val.replace('\n', '<br>');
}
// 创建新的LI标签
var newLi = document.createElement('li');
// 给LI添加内容
newLi.innerHTML = val;
// 将LI插入到UL的最后位置
list.appendChild(newLi);
// 清空输入框
msg.value = '';
};
</script>
综合应用:
1:统计字符串中每个字符的个数。
// 比如:{a: 2, b: 2, c:2, e:1, f: 2, t: 1}
var str = 'abcbacefft';
var obj = {};
for(var i = 0; i < str.length; i++) {
var char = str.charAt(i);
if(obj[char]) { //如果不存在就是undefined 转成布尔值是false
obj[char]++;
} else {
obj[char] = 1;
}
}
// 将对象拼接成字符串
var str = '';
for(var attr in obj) {
str += attr + obj[attr] + '、';
}
str = str.slice(0, -1);
console.log(str);
2:统计每个字符出现的次数,结果显示 a 2、b 1、c 2、d1,去掉重复的字符,使结果显示 abcdfgj。
// {a: 2, b: 2, c:2, e:1, f: 2, t: 1}
var str = 'abcbacefft';
var obj = {};
for(var i = 0; i < str.length; i++) {
var char = str.charAt(i);
if(obj[char]) {
obj[char]++;
} else {
obj[char] = 1;
}
}
// 将对象拼接成字符串
var str = '';
for(var attr in obj) {
str += attr + obj[attr] + '、';
}
str = str.slice(0, -1);
console.log(str);