标签:需要 构造 局部变量 for 调用函数 重复执行 单词 区分 模块
好程序员web前端学习路线分享函数基础,在这之前先来讲一下函数是什么?函数就一个代码块,可以是一个完全独立与其它内容没有关系的代码块,也可以是一个与外界环境紧密相关的代码块。函数是一个拥有输入和输出的独立代码块。函数是程序中最重要的组成部分。
函数,是一种封装(将一些语句,封装到函数里面)。通过函数可以封装任意多条语句,而且可以在任何地方、任何时候调用执行。
在javascript里,函数即对象,程序可以随意操控它们。函数可以嵌套在其他函数中定义,这样它们就可以访问它们被定义时所处的作用域中的任何变量,它给javascript带来了非常强劲的编程能力。
函数的功能、好处:
1) 将会被大量重复的语句写在函数里面,这样以后需要这些语句的时候,直接调用函数,不用重写那些语句。
2) 简化编程,让编程变的模块化。
函数的声明
函数有三种声明的方法,而且有各自不同的特点。
1、普通函数声明
函数关键字 + 函数名 + (){
????????????????????????语句
????????????????????????函数体
????????} ??
例如:
???????????????
function functionName(){
????alert("程序员的摇篮");
???// ...语句//
}
注:1.函数命名跟变量一样,只能是字母、数字、下划线、美元符号,不能以数字开头。
2.后边()里放参数用的
函数名的规范:
1、普通的函数使用,名称需要驼峰式命名法,即函数是多个词组构成时,第一个单词的首字母小写,其余的单词首字母大写。函数名不能与关键词和保留字重复,不能与变量名重复。
2、类的构造函数,是驼峰式命名,但是第一个单词首字母需要大写。
2、匿名函数声明
var ?变量名称 = function (){
??????函数内容
}
var funName=function () {
????//函数内容
};
定义一个匿名函数,所谓匿名函数就是没有函数名。但是匿名函数定义后如果不保存在一个变量中,就找不到了,因此,我们通常会用一个变量接收这个匿名函数。
匿名函数尾部结束时需要用;来结束,普通的函数结束后不用;结束的。
var funName=function abc() {
????//函数内容
????console.log(abc);
}
匿名函数也是可以定义函数名称的,只不过比的地方不能使用,只能在函数内部使用。
3、Function构造函数声明
使用Function构造函数
var box=new Function(‘num1‘,‘num2‘,‘retun num1+num2‘);//num1,num2参数
??num1,num2参数, 最后的字符串是函数体
注意:第三种方式我们不推荐,因为这种语法会导致解析两次代码(第一次解析常规JS代码,第二次是解析传入构造函数中的字符串),从而影响性能,但我们可以通过这种语法来理解函数是对象,函数名是指针的概念。
函数的存储
JavaScript程序是一种解释性语言。那么什么时候解释性语言呢。
计算机其实并不认识程序,不管是什么代码计算机都不认识,因为计算机只是机器,如果我们需要让计算机认识程序,那么就需要一个翻译,就是把程序代码变成计算机可以理解的语言:0和1的信息序列。目前存在两种翻译类型:一个是编译,一个是解释。两种方式都需要对代码进行翻译,只是翻译的时间不同而已。
编译型语言在计算机运行代码前,先把代码翻译成计算机可以理解的文件,这种文件计算机就能看懂了,但是不管是程序员还是其他人员都看不懂的。并且这种代码,计算机可以执行了,但是每次我们需要修改代码时都需要修改源代码,然后再进行编译新的文件才可以使用,也就是不能再编译好的文件上修改。这种代码的优势是运行速度快,在执行前就知道代码是否错误,因为编译时就做了判断。
解释型语言则不同,解释型语言的程序不需要在运行前编译,在运行程序的时候才翻译,专门的解释器负责在每个语句执行的时候解释程序代码。这样解释型语言每执行一次就要翻译一次,效率比较低。而且执行时才知道代码是否错误。
而JavaScript就是解释性语言。但是注意程序在运行的时候,解释器首先会收集所有的普通定义的函数,并且把他们存储在堆里,这时候才从头开始执行代码。
abc();
function abc() {
???
}
例如我们看到这里abc的执行在函数的上面,如果按照代码的执行顺序,应该先执行abc,再创造函数,那么显然就会报错。但是这样不会有问题。就是说明,函数首先会被收集在堆里,不管在哪里调用,都是调用堆里的函数,因此普通定义的函数执行时可以写在前面或者写在后面。
但是注意如果我们使用匿名函数这种情况就不同了。虽然我们会收集匿名函数在堆里,但是如果找到它时,我们就需要在把它赋给一个变量以后才可以执行,否则就会报错。
abc();
var abc=function () {
???
}
这是错误的。
例如上面这种就是错误的。
函数的参数
参数是指由外部传入到函数中的变量,仅作为变量使用,但是该变量可以是任何内容,包括函数。
被传入的参数作为局部变量使用,可以被覆盖掉。
参数就是一个局部变量,通过外界传入值,这个参数就是对应的值。参数是按照顺序填入的。参数在JavaScript中不要求写入参数的类型和默认值,如果需要默认值,就需要在函数中,根据条件判断增加默认的值。有时候我们可以不用定义参数,直接在函数调用时,带入参数,也可以获取到。(不建议大家使用)
为什么要从外部带入参数。一般来说函数是独立处理某段代码的集合,如果,这段代码需要重复执行,就会设计出函数,在不同的地方调用,达到代码共用的目的,减少代码量。但是在某些时候,虽然是同样的代码,但是我们需要它发挥出的作用更大,可以解决不同的问题,这时候,传入的参数就可以起到代码干预作用,在同一个函数中解决了很多不同的问题。这时候设计函数的独立性就显得非常重要了。当然,任何事情解决都不是绝对的,过度设计复杂的函数有时候反到会让代码效率降低。
????????同时,外部传入的参数可以节省全局变量的定义,甚至保证函数中的部分变量的独立性。
参数分为实参和形参。
实参:真实的数值、字符串
形参:一个接收实参的变量
例如这里是通过一个函数中的参数来控制在页面上添加多少个li
var m=5;
createUl(m);
function createUl(n) {
????if(n<1 || isNaN(n)) n=1;
????var ul="<ul>";
????for(var i=0;i<n;i++){
????????ul+="<li>列表"+(i+1)+"</li>";
????}
????ul+="</ul>";
????document.write(ul);
}
函数的返回值
return 语句会终止函数的执行并返回函数的值。return 是javascript里函数返回值的关键字,一个函数内处理的结果可以使用return 返回,这样在调用函数的地方就可以用变量接收返回结果。return 关键字内任何类型的变量数据或表达式都可以进行返回,甚至什么都不返回也可以
abc(3,5);
function abc(a,b){
???return a+b;
}
注意return只能返回一个值,如果需要返回多个数据时可以考虑数组或者对象,例如
function abc() {
????return {a:1,b:2};
}
return 也可以作为阻止后续代码执行的语句被使用,例如
var bool=false;
var i=0;
function abc(){
????if(bool) return;
????i++;
}
这样可以有效的控制语句在一定的条件下执行,不过一定要与break区分,break是用在条件当中,跳出的也仅仅是条件和循环,但是return 却可以跳出函数,仅仅是针对函数使用,如果没有函数是不能使用return的。
abc();
function abc() {
????for(var i=0;i<10;i++){
????????if(i===3){
????????????// break;
????????????return;
????????}
????}
????i+=5;
????console.log(i);//i=8
}例如上面的例子,如果使用break,就会打印i的值是8,如果使用return,就不会打印了,因为return直接跳出了函数。
函数的执行
函数的执行分为两种
1、普通函数执行
函数执行 :函数名()
执行后,可以完成函数的代码内容,如果函数内有return 值,这时候执行后会返回该值。
function abc() {
????return 3+4;
}
var s=abc();
如何没有return,则执行完所有代码
2、函数独立执行
函数自身是可以独立执行的,并且也可以把独立执行的结果赋值给一个变量。
var s=0;
(function(){
????s=4+5
})();
左边是匿名函数自己执行,右边是匿名函数赋值
注意匿名函数用小括号括住,最后再执行小括号。
注意,除了匿名函数可以独立执行,实名函数也是可以独立执行的,不过这种独立执行就不能在该函数中添加参数了,并且匿名函数,也只能在此执行一次,不能多次调用,显而易见的好处是,该函数内的变量统统是私有变量,有关该部分内容我们在后面详细说明
函数的删除
当函数不在使用时,就需要删除,函数也是对象,如果不删除,它将常驻内存中,如果该函数不再使用就可以使用删除彻底清除掉该函数。但是只有函数是匿名定义的或者通过构造函数创建的才可以被删除。
函数删除分两种
1、匿名函数删除
函数=null
2、对象下函数删除
delete obj.fun
标签:需要 构造 局部变量 for 调用函数 重复执行 单词 区分 模块
原文地址:https://blog.51cto.com/14479068/2439200