1、函数声明方式
1)普通声明方式
 function box(num1,num2){
      return num1 + num2;
 }
2)使用变量初始化函数
var box = function(num1,num2){
     return num1 + num2;
}
3)使用function构造函数
var box = new Function('num1','num2','return num1 + num2');不推荐
2、作为值的函数??:可像传递参数一样把一个函数传递给另一个函数,也可将一个函数作为另一个函数的结果范回。(回调函数)
function box(sumFunction,num){
 
  return sumFunction(num);    
 
}
function sum(sum){
  return num + 10;
}
var result = box(sum,10);//传递函数到另一个函数
理解:回调函数典型示例
eg. var  friends = ['Linda','Mike','Bob','Lucy'];
   
     friedns.forEach(function(name,index){//没有函数名的匿名函数
     console.log(index+1+'.'+name);//1.Linda ,2.Mike, 3.Bob,4.Lucy
 });
回调函数实现原理:
我们可以像使用变量一样使用函数,作为另一个函数的参数,在另一个函数中作为返回结果,在另一个函数中调用它。当我们作为参数传递一个回调函数给另一个函数时,我们只传递了这个函数的定义,并没有在参数中执行它。
当包含(调用)函数拥有了在参数中定义的回调函数后,它可以在任何时候调用(也就是回调)它。
这说明回调函数并不是立即执行,而是在包含函数的函数体内指定的位置“回调”它(形如其名)。所以,即使第一个jQuery的例子看起来是这样:
3、函数内部属性
1)函数内部的特殊对象:arguments
arguments是一个类数组对象,包含传入函数中的所有参数,主要用于保存函数参数;该对象有个属性callee,即指针,可指向拥有该对象的函数。
function arg(n1) {
          if (n1 <= 1) {
            return 1;
          } else {
            return n1 * arg(n1 - 1);//阶乘函数-递归算法(调用自身)
          }
        }
 console.log(arg(4));//n1=3,arg(3)=3*2=6;n1=6,arg(6)= 6*5*4*3*2=720
/*使用arguments.callee的原因:消除函数执行与函数名紧密耦合,
        * 即函数名改变后内部自身调用不用逐一修改
        * */
        function arg1(n2) {
          if (n2 <= 1) {
            return 1;
          } else {
            return n2 * arguments.callee(n2 - 1);//在严格模式下不能通过脚本访问会报错
          }
        }
        console.log(arg1(4));//控制台报错
2)函数内部的特殊对象:this
 this引用的是函数数据以执行操作的对象,或者说函数调用语句所处的那个作用域;当在全局作用域中调用函数时,this对象引用的就是window。
1.// 在全局变量中,this为window
    window.onload= function(){
        alert(window);//object window
    }
    this.onload= function(){
        alert(this);//object window
    }
2.//在函数中时,this为window对象
   function obj(pra){
        this.sear = pra;
    }
    obj("this为window对象");
    alert(sear);
3.//this在对象中,this就为该对象 
    var name = "对象";
    var person = {
        name: "user",
        xiu: function(){
            alert(this.name);//person内部的name
        }
    }
    person.xiu();//user
4.//this遇上new时,this为新创建的对象(obj)
  function Fun(){
        this.name = "新对象";
    }
    var obj = new Fun();
    alert(obj.name); //新对象
5. //this在内部函数中,this为window
   var name = "内部函数";
    var person = {
        name : "user",
        hello : function(){
            var sayhello = function() {
                alert(this.name);
            };
            sayhello();
        }
    }
person.hello();//内部函数
6.//this在内部函数中,若在对象中将this作为变量保存下来,this就指向该对象
var name = "修抗";
    var person = {
        name : "user",
        hello : function(){
            var th = this;
            var sayhello = function() {
                alert(th.name);
            };
            sayhello();
           }
    }
person.hello();//user

js基础——function类型的更多相关文章

  1. JS基础-变量类型和类型转换

    JS 变量类型 JS中有 6 种原始值,分别是: boolean number string undefined symbol null 引用类型: 对象 数组 函数 JS中使用typeof能得到哪些 ...

  2. Js函数function基础理解

    正文:我们知道,在js中,函数实际上是一个对象,每个函数都是Function类型的实例,并且都与其他引用类型一样具有属性和方法.因此,函数名实际上是指向函数对象的指针,不与某个函数绑定.在常见的两种定 ...

  3. js基础知识--变量类型和变量计算

    提问: JS中使用typeof能得到的哪些类型 何时使用===何时使用== JS中有哪些内置函数 JS变量按照存储方式区分为哪些类型,并描述其特点 如何理解JSON 涉及知识点:(1)变量类型 值类型 ...

  4. 【js实例】Array类型的9个数组方法,Date类型的41个日期方法,Function类型

    前文提要:[js实例]js中的5种基本数据类型和9种操作符 Array类型的9个数组方法 Array中有9个数组方法: 1.检测数组 2.转换方法 3.栈方法 4.队列方法 5.冲排序方法6.操作方法 ...

  5. JS Function类型

    每个函数都是Function类型的实例,由于函数是对象,函数名实际上是一个指向函数对象的指针,不会与某个函数绑定. 1.函数的声明: (1)函数声明语法: function sum (num1,num ...

  6. javascript基础篇--function类型(上)

    在js中,function类型实际上是对象,每一个函数都是function类型的一个实例.并且与其它引用类型一样具有属性和方法. 声明 1普通方式 Function sum(num1,num2) { ...

  7. JS基础知识点——原始类型和对象类型的区别

    1.js类型 1.1 JavaScript语言规定了7种语言类型,他们分别是: Number(数字) Boolean(布尔值) String(字符串) Null (空) Undefined (未定义) ...

  8. 【笔记】js Function类型 内部方法callee

    运用function实现阶乘 以往的做法是如下的 function factorial(num){ if(num <= 1){ return 1; }else{ return num * fac ...

  9. Javascript 基础学习(三)js 的原始类型和声明变量

    java的基本数据类型一共有 byte short int long float double char boolean js中定义变量使用关键字 var js的原始类型(五个) String: 字符 ...

随机推荐

  1. LintCode刷题笔记-- Count1 binary

    标签: 位运算 描述: Count how many 1 in binary representation of a 32-bit integer. 解题思路: 统计一个int型的数的二进制表现形式中 ...

  2. linux中各目录及详细介绍

    一.Linux文件系统的层次结构 在Linux或UNIX操作系统中,所有的文件和目录都被组织成一个以根节点开始的倒置的树状结构,如图: 二.目录 1.目录的定义 目录相当于Windows中的文件夹,目 ...

  3. 【7.19 graphshortestpath graphallshortestpaths函数】matlab 求最短路径函数总结

    graphshortestpath 函数是用来解决最短路径问题的. 语法为: [dist, path, pred]=graphshortestpath(G,S) [dist, path, pred]= ...

  4. hdu3879 最大权闭合图

    若a,b 2点能够相连,那么可以得到ci的价值,也就是说a,b是得到c的前提条件,对于每一个点,又有耗费. 对于本题,先求出最多能够得到的利益有多少,最小割=未被 选的用户的收益之和 + 被选择的站点 ...

  5. python 别名

  6. 【风马一族_php】NO4_php基础知识

    原文来自:http://www.cnblogs.com/sows/p/6017018.html(博客园的)风马一族 侵犯版本,后果自负 回顾 运算符:算术运算符.逻辑运算符.比较运算符.位运算符.赋值 ...

  7. TCPThree_C杯 Day1

    题解 或 正规题解 已经很详细,不再赘述. 跟着wjx打代码,不怕卡题. 忘开long long智障错误第四次左偏树

  8. sql函数的使用——系统函数

    n  sys_context 1)terminal:当前会话客户所对应的终端的标识符 2)lanuage:语言 3)db_name:当前数据库名称 4)nls_date_format:当前会话客户端所 ...

  9. 提供SaaS Launchkit,快速定制,一云多端等能力,一云多端将通过小程序云实现

    摘要: SaaS加速器的技术中心能力中,将提供SaaS Launchkit,快速定制,一云多端等能力,加速应用上云迁移.降低应用开发和定制的门槛,提升效率.其中非常关键的一云多端能力将通过小程序云实现 ...

  10. HZOJ trade

    强烈谴责$skyh$的没$\Huge 脸$行为. 很经典的可反悔贪心,然而我一直以为是sbdp还一直想着怎么优化…… 正常的贪心肯定是不对的. 但是由于A-C=A-B+B-C, 所以用一个小根堆维护, ...