Javascript基础学习(三)

一、闭包

1.执行环境:变量或函数有权访问的其他数据,决定了它们各自的行为。
2.作用域链:全局执行环境是最外围的一个执行环境,活动最开始只包括一个变量,即arguments对象(这个对象在全局中是不存在的),作用域中的下一个变量来自于外部环境,全局执行环境的变量对象始终是作用域中最后一个对象。
3.闭包:就是能够读取其他函数内部变量的函数。由于内部的子函数才能读取局部变量。
4.闭包会导致原有的作用域不被释放,造成内存泄漏。

 script
        function fn1(){
            function fn2(){
                alert("HelloWorld!")
            }
            return fn2;
        }
        var fn=fn1();//HelloWorld!
        fn();
 /script
二、arguments对象

本质:是当前函数的参数列表,类似于数组的集合,使用索引值来取。

 function f1(a,b,c){
//         *arguments 是当前函数的参数列表  类似于数组的集合  使用索引值来取
         console.log(arguments.length);
         }
         f1(1,2,3);
function fun(n,o) {
         console.log(o);
         return {
         fun:function(m){
         return fun(m,n);
         }
         };
         }
         var a = fun(0);  a.fun(1);  a.fun(2);  a.fun(3);
         var b = fun(0).fun(1).fun(2).fun(3);
         var c = fun(0).fun(1);  c.fun(2);  c.fun(3);
       function f1(a,b,c){
//         *arguments 是当前函数的参数列表  类似于数组的集合  使用索引值来取
         console.log(arguments.length);
         }
         f1(1,2,3);
      var sum = function () {
            var cache;
            if (arguments.length === 1) {
                cache = arguments[0];//如果arguments对象的长度为1,也就是参数只有1个时,将这个参数赋值给cache,暂存
                return function (number) {//返回一个函数,函数里的参数(也就是第二个括号里的参数)与之前第一个括号里的参数相加
                    return cache + number
                }
            } else {
                return arguments[0] + arguments[1];//如果arguments对象的长度不为1,那么两个参数相加
            }
        };
        console.log(sum(2, 53));//5
        console.log(sum(2)(3));
三、语句

1.if语句(流控制语句)

if(条件表达式){
        语句1
    }
    else{
        语句2
    }

2.switch语句( 流控制语句)

switch(表达式){
	case value:语句1
	break;
	case value:语句2
	break;
	case value:语句3
	break;
	case value:语句4
	break;
	default:语句5
}

case:如果表达式等于这个值(value),则执行后面的语句。而break关键字是跳出switch语句。如果省略break关键字,就会导致执行完当前的case后,继续执行下一个case。default则用于表达式不匹配前面的任何一种情形时,执行机动代码。

3.do-while语句 (后测试循环语句)
后测试循环语句定义:只有在循环体中的代码执行之后,才会测试出口条件。
语法:

do{
	语句1
}
while(条件表达式)

4.while语句 (后测试循环语句)

初值;
while(条件表达式) {
	循环体;
	步长;
}

5.for语句(前测试语句)
前测试语句定义:在执行循环之前初始变量和定义循环之后的执行代码。

for(初值;条件表达式;步长){
	循环体
}

6.for-in语句(精准的迭代语句可以用来枚举对象的属性)。循环遍历
语法:

for(变量 in 集合) 语句

7.break和continue语句
break语句会立即退出循环,强制继续执行后面的语句。
continue语句虽然也会立即退出循环,但退出循环后会从循环的顶部继续执行。

var num=0;
for(var i=1;i10;i++){
	if(i%5==0){
		break;
	}
	num++;
}
alert(num);//结果是4
var num=0;
for(var i=1;i10;i++){
	if(i%5==0){
		continue;
	}
	num++;
}
alert(num);//结果是8
四、函数的递归

定义:函数反复调用自己,直到最终结果 跳出。
例:求5的阶乘。

function jiecheng(n){
           if(n==0)
           {
               return 1;
           }
           return jiecheng(n-1)*n;
 }
 console.log(jiecheng(5));
五、 javascript自带函数

1.concat
将两个或多个字符的文本组合起来,返回一个新的字符串。
var a = hello;
var b = ,world;
var c = a.concat(b);
alert(c);
//c = hello,world
indexOf
2.返回字符串中一个子串第一处出现的索引(从左到右搜索)。如果没有匹配项,返回 -1 。
var index1 = a.indexOf(l);
//index1 = 2
var index2 = a.indexOf(l,3);
//index2 = 3
charAt
3.返回指定位置的字符。
var get_char = a.charAt(0);
//get_char = h
lastIndexOf
4.返回字符串中一个子串最后一处出现的索引(从右到左搜索),如果没有匹配项,返回 -1 。
var index1 = lastIndexOf(‘l’);
//index1 = 3
var index2 = lastIndexOf(‘l’,2)
//index2 = 2
match
5.检查一个字符串匹配一个正则表达式内容,如果么有匹配返回 null。
var re = new RegExp(/^\w+$/);
var is_alpha1 = a.match(re);
//is_alpha1 = hello
var is_alpha2 = b.match(re);
//is_alpha2 = null
substring
6.返回字符串的一个子串,传入参数是起始位置和结束位置。
var sub_string1 = a.substring(1);
//sub_string1 = ello
var sub_string2 = a.substring(1,4);
//sub_string2 = ell
substr
7.返回字符串的一个子串,传入参数是起始位置和长度
var sub_string1 = a.substr(1);
//sub_string1 = ello
var sub_string2 = a.substr(1,4);
//sub_string2 = ello
replace
8.用来查找匹配一个正则表达式的字符串,然后使用新字符串代替匹配的字符串。
var result1 = a.replace(re,Hello);
//result1 = Hello
var result2 = b.replace(re,Hello);
//result2 = ,world
search
9.执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
var index1 = a.search(re);
//index1 = 0
var index2 = b.search(re);
//index2 = -1
slice
10.提取字符串的一部分,并返回一个新字符串(与 substring 相同)。
var sub_string1 = a.slice(1);
//sub_string1 = ello
var sub_string2 = a.slice(1,4);
//sub_string2 = ell
split
11.通过将字符串划分成子串,将一个字符串做成一个字符串数组。
var arr1 = a.split("");
//arr1 = [h,e,l,l,o]
length
12.返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。
var len = a.length;
//len = 5
toLowerCase
13.将整个字符串转成小写字母。
var lower_string = a.toLowerCase();
//lower_string = hello
toUpperCase
14.将整个字符串转成大写字母。
var upper_string = a.toUpperCase();
//upper_string = HELLO

最新回复(0)
/jishuQKOXMqUjU2ZqfYM61Y2NLCktkOb4shDe4E9u5A_3D_3D4488409
8