function
 
1.  定义:一段预先设置的代码块,可以反复调用,根据输入参数的不同,返回不同的值;
 
2.  函数的声明方法:
    (1)function 命令声明函数  function  fname(  ){    };
    (2)函数表达式: var  a=function( ){    } ;
    (3)Function 构造函数:var a=new Function(  )  ;    ——不常用;、
 
3.  函数的覆盖:   函数若被重复声明,后面的声明会覆盖前面的声明;
 
4.  函数的调用方法:(1)、()运算符    funcName( )  ,()可以加入函数的参数;
                                 (2)、 window . funcName( )
 
5.return :   函数体内部可以加入return语句,return所带的表达式是函数返回值;
 
6.不允许在非函数代码中声明函数,允许函数套函数;
 
7.(1)name属性: 返回紧跟在function关键字之后的那个函数名;
 
   (2)length属性: 返回形参的个数;
 
   (3)arguments (类数组) :返回函数实参的个数;
            函数传参:形参,实参
                       function abc( 形参1,形参2,.......形参n){
                    ... 实参1,2,.....n

 判断实参arguments,且arguments 类似数组
 
8.  函数的参数不是必需的,js允许省略参数;
 
9.  自执行函数 :(1)  (function(){   code } )();
 
                               eg:   ( kk=function(){

                alert("测试自执行");
})();
             (2)(function(){   code } ());

                eg: ( LL=function(){
                alert('22222');
}()) ; (3) !function(){ code }();
                 eg: !function(){
                alert('3333');
}();
10.  函数的作用域(scope):变量存在的范围;
    1、全局作用域            (整个window都可以调用)
2、函数(局部)作用域 (指的是函数内部变量)
        (1)在函数外部声明的变量就是全局变量(global  variable);在函数内部可以使用全局变量(整个window都可以调用);
        (2)在函数内部定义的变量,外部无法读取,称为“局部变量”;
 
11.闭包
    函数内部声明变量一定要用var,否则声明了一个全局变量;
    闭包本质:将函数内部和外部连接起来的桥梁,可以简单理解为函数套函数。
    闭包的用处: 1.读取函数内部变量
                        2.让这些变量始终保持在内存中,闭包使它的诞生环境一直存在
                        3.封装对象的私有属性和私有方法
  
 
 ---------------------------------------------以下内容来自搜索整理------------------------------------------------

闭包原理及应用
 
1.为什么需要闭包?
    保护函数内的变量安全。在内存中维持一个变量。
    通过保护变量的安全实现JS私有属性和私有方法(不能被外部访问)
 
 
2.怎么释放被闭包的变量内存?
在Javascript中,如果一个对象不再被引用,那么这个对象就会被GC回收。如果两个对象互相引用,而不再被第3者所引用,那么这两个互相引用的对象也会被回收。因为函数a被b引用,b又被a外的c引用,这就是为什么函数a执行后不会被回收的原因。
 
 
3.代码中函数a的内部函数b,被函数a外面的一个变量c引用的时候,这就叫创建了一个闭包。有时候函数b也可以用一个匿名函数代替来返回,即return function(){};

优点:1.保护函数内的变量安全,加强了封装性

     2.在内存中维持一个变量(用的太多就变成了缺点,占内存)
      闭包之所以会占用资源是当函数a执行结束后, 变量i不会因为函数a的结束而销毁, 因为b的执行需要依赖a中的变量。

4.不适合场景:返回闭包的函数是个非常大的函数

闭包的典型框架应该就是jquery了。
闭包是javascript语言的一大特点,主要应用闭包场合主要是为了:设计私有的方法和变量。
这在做框架的时候体现更明显,有些方法和属性只是运算逻辑过程中的使用的,不想让外部修改这些属性,因此就可以设计一个闭包来只提供方法获取。

5.闭包的缺点就是常驻内存,会增大内存使用量,使用不当很容易造成内存泄露。

 
 
 
 
 <---------学习笔记,谢谢指正!-------->
 

JavaScript-Function基础知识的更多相关文章

  1. 快速掌握JavaScript面试基础知识(三)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  2. 快速掌握JavaScript面试基础知识(二)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  3. javascript的基础知识及面向对象和原型属性

    自己总结一下javascript的基础知识,希望对大家有用,也希望大家来拍砖,毕竟是个人的理解啊 1.1 类型检查:typeof(验证数据类型是:string) var num = 123; cons ...

  4. JavaScript 之基础知识

    JavaScript 基础知识 JavaScript 是属于网络的脚本语言! JavaScript 被数百万计的网页用来改进设计.验证表单.检测浏览器.创建cookies,以及更多的应用. JavaS ...

  5. JavaScript对象基础知识总结

    1.什么叫JavaScript对象? 定义:名值对的集合.简单的讲就是容纳属性值和属性值的容器,这些属性可以是无序的,基本上JavaScript中所有的事物都可以看成对象. 拓展:我们经常说,数组也是 ...

  6. JavaScript笔记——基础知识(一)

    <Script>标签属性 <script>xxx</script>这组标签,是用于在 html 页面中插入 js 的主要方法.它主要有以下 几个属性: charse ...

  7. JavaScript事件基础知识总结【思维导图】

    另外附上来自Nicholas C.Zakas<JavaScript高级程序设计 第3版>中的跨浏览器兼容EventUtil对象. var EventUtil = { //注册事件 addH ...

  8. JavaScript语言基础知识8

    这篇文章是对前面学习的知识进行总结: 1.JavaScript支持多种数据类型,如数值类型.字符串类型.布尔类型等. 2.在JavaScript中,字符串是用引號括起来的字符系列,转义字符能够用来表示 ...

  9. JavaScript笔记——基础知识(二)

    Function类型 函数function不需要返回类型(不是没有返回值),参数也不需要指定类型,更为特殊的是函数竟然是个类,可以通过new出来 var box= new Function('num1 ...

  10. 快速了解JavaScript的基础知识

    注释 单行注释: // 单行注释 多行注释: /* 多行 注释 */ 历史上 JavaScript 可以兼容 HTML 注释,因此 <!-- 和 --> 也可以是单行注释. x = 1; ...

随机推荐

  1. yii2 登录用户和未登录用户使用不同的 layout

    可以在配置文件中增加一个 “beforeRequest” 事件: 'on beforeRequest' => function () { Yii::$app->layout = Yii:: ...

  2. ffmpeg-201612[01,08,10,17,21,27,30]-bin.7z

    ESC 退出 0 进度条开关 1 屏幕原始大小 2 屏幕1/2大小 3 屏幕1/3大小 4 屏幕1/4大小 5 屏幕横向放大 20 像素 6 屏幕横向缩小 20 像素 S 下一帧 [ -2秒 ] +2 ...

  3. Python: with...as...

    with open(path, 'r') as f: Soup = BeautifulSoup(f.read(), 'lxml') titles = Soup.select('ul > li & ...

  4. js随机生成颜色代码

    function generyRandomColor() { return '#' + ('00000' + (Math.random() * 0x1000000 << 0).toStri ...

  5. 常用的HTML代码

    一.文字1.标题文字 <h#>..........</h#> #=1~6:h1为最大字,h6为最小字 2.字体变化 <font>..........</fon ...

  6. 微信公众平台oauth2.0网页授权参考资料

    http://www.wangwenxiao.com/weixin/wxgzptoauth2_0wysq_12.html

  7. div不换行_div同行_div强制不换行

    使用Float <!--已知两个div的宽度使用[Float]使两个DIV同行!注:float使用后需要清除:所以多写一个div--> <div style="width: ...

  8. VirtualBox上搭建Ubuntu开发环境

    软件版本: VirtualBox虚拟机:5.1.8 for Windows hosts  x86/amd64 Ubuntu系统:Ubuntu 14.04.5 LTS  Desktop (32-bit) ...

  9. php结合md5的加密解密算法实例

    <?php /* * Created on 2016-12-22 * */ function encrypt($data, $key){ $key = md5($key); $x = 0; $l ...

  10. svn: how to set the executable bit on a file?

    http://stackoverflow.com/questions/17846551/svn-how-to-set-the-executable-bit-on-a-file svn uses pro ...