每天一篇javascript学习小结(Function对象)


Posted in Javascript onNovember 16, 2015

小编两天都没有更新文章了,小伙伴们是不是等着急了,今天开始再继续我们的《每天一篇javascript学习小结》系列文章,希望大家继续关注。

1、Function  函数调用(类似call方法)

function callSomeFunction(someFunction, someArgument){
      return someFunction(someArgument);
    }

    function add10(num){
      return num + 10;
    }
    
    var result1 = callSomeFunction(add10, 10);//调用add10 把参数10传给add10
    alert(result1);  //20
    
    function getGreeting(name){
      return "Hello, " + name;
    }
    
    var result2 = callSomeFunction(getGreeting, "Nicholas");
    alert(result2);  //Hello, Nicholas

2、函数返回函数
 

function createComparisonFunction(propertyName) {
    
      return function(object1, object2){
        var value1 = object1[propertyName];
        var value2 = object2[propertyName];
    
        if (value1 < value2){
          return -1;
        } else if (value1 > value2){
          return 1;
        } else {
          return 0;
        }
      };
    }

    var data = [{name: "Zachary", age: 28}, {name: "Nicholas", age: 29}];
    
    data.sort(createComparisonFunction("name"));//sort函数接收一个函数作为排序的参考,函数createComparisonFuntion返回了一个匿名的排序函数
    alert(data[0].name); //Nicholas
    
    data.sort(createComparisonFunction("age"));
    alert(data[0].name); //Zachary

3、apply()方法使用

function sum(num1, num2){
      return num1 + num2;
    }
    
    function callSum1(num1, num2){
      return sum.apply(this, arguments);//sum函数请求把callSum1的指针传给自己,并作计算,此时的this指向callSum1
    }
    
    function callSum2(num1, num2){
      return sum.apply(this, [num1, num2]);
    }
    
    alert(callSum1(10,10));  //20
    alert(callSum2(10,10));  //20

4、函数Arguments Caller使用

function outer(){
      inner();
    }
    
    function inner(){
      alert(inner.caller);
    }
    
    outer();
caller

//返回一个对函数的引用,该函数调用了当前函数。

5、arguments.callee.caller
 

function outer(){
      inner();
    }
    function inner(){
      alert(arguments.callee.caller);
      //argments.callee就是函数体本身,arguments.callee.caller就是函数体的调用函数体
    }
    outer();


function factorial(num){
      if (num <= 1) {
        return 1;
      } else {
        return num * arguments.callee(num-1)//callee当前函数的引用即factorial函数本身的函数体
      }
    }

    var trueFactorial = factorial;
    
    factorial = function(){
      return 0;
    };
    
    alert(trueFactorial(5));  //120
    alert(factorial(5));    //0

6、Funtion bind()方法

window.color = "red";
    var o = { color: "blue" };
              
    function sayColor(){
      alert(this.color);
    }
    var objectSayColor = sayColor.bind(o);
    objectSayColor();  //blue
    /*
      bind主要是为了改变函数内部的this指向,这个是在ECMA5以后加入的,所以IE8一下的浏览器不支持
      bind方法会创建一个新函数,称为绑定函数.当调用这个绑定函数时,绑定函数会以创建它时传入bind方法的第一个参数作为this,
      传入bind方法的第二个以及以后的参数加上绑定函数运行时本身的参数按照顺序作为原函数的参数来调用原函数.
    */

7、Function call()方法

window.color = "red";
    var o = { color: "blue" };
    
    function sayColor(){
      alert(this.color);
    }
    
    sayColor();      //red
    
    sayColor.call(this);  //red 此时this指向window
    sayColor.call(window); //red 同上
    sayColor.call(o);   //blue 此时sayColor的指针指向o

 function sum(num1, num2){
      return num1 + num2;
    }
    
    function callSum(num1, num2){
      return sum.call(this, num1, num2);
    }
    
    alert(callSum(10,10));  //20

8、函数长度length

function sayName(name){
      alert(name);
    }   
    
    function sum(num1, num2){
      return num1 + num2;
    }
    
    function sayHi(){
      alert("hi");
    }
    
    alert(sayName.length); //1
    alert(sum.length);   //2
    alert(sayHi.length);  //0
    //实际返回的是函数的参数的长度

以上就是今天的javascript学习小结,之后每天还会继续更新,希望大家继续关注。

Javascript 相关文章推荐
用Javascript来生成ftp脚本的小例子
Jul 03 Javascript
alert出数组中的随即值代码
Sep 25 Javascript
Javascript中的Callback方法浅析
Mar 15 Javascript
js实现浏览本地文件并显示扩展名的方法
Aug 17 Javascript
jQuery插件开发汇总
May 15 Javascript
jQuery实现Select下拉列表进行状态选择功能
Mar 30 jQuery
angular项目中bootstrap-datetimepicker时间插件的使用示例
Mar 15 Javascript
详解如何为你的angular app构建一个第三方库
Dec 07 Javascript
小程序:授权、登录、session_key、unionId的详解
May 15 Javascript
Vue 实现一个命令式弹窗组件功能
Sep 25 Javascript
如何使用webpack打包一个库library的方法步骤
Dec 18 Javascript
Vue自定义铃声提示音组件的实现
Jan 22 Vue.js
举例讲解JavaScript中关于对象操作的相关知识
Nov 16 #Javascript
实例代码详解jquery.slides.js
Nov 16 #Javascript
jQuery实现标题有打字效果的焦点图代码
Nov 16 #Javascript
JavaScript中对DOM节点的访问、创建、修改、删除
Nov 16 #Javascript
常用javascript表单验证汇总
Jul 20 #Javascript
jquery验证邮箱格式是否正确实例讲解
Nov 16 #Javascript
跟我学习javascript的call(),apply(),bind()与回调
Nov 16 #Javascript
You might like
php常用ODBC函数集(详细)
2013/06/24 PHP
phpmyadmin出现Cannot start session without errors问题解决方法
2014/08/14 PHP
PHP中substr()与explode()函数用法分析
2014/11/24 PHP
PHP简单实现二维数组的矩阵转置操作示例
2017/11/24 PHP
JS中style属性
2006/10/11 Javascript
javascript拓展DOM操作 prependChild insertAfert
2010/11/17 Javascript
js+xml生成级联下拉框代码
2012/07/24 Javascript
jQuery中add()方法用法实例
2015/01/08 Javascript
JavaScript使用yield模拟多线程的方法
2015/03/19 Javascript
AngularJS进行性能调优的7个建议
2015/12/28 Javascript
jQuery实现的模拟弹出窗口功能示例
2016/11/24 Javascript
jQuery实现简单的滑动导航代码(移动端)
2017/05/22 jQuery
js实现登录与注册界面
2017/11/01 Javascript
vue实现五子棋游戏
2020/05/28 Javascript
webpack 如何同时输出压缩和未压缩的文件的实现步骤
2020/06/05 Javascript
解决vant title-active-color与title-inactive-color不生效问题
2020/11/03 Javascript
jquery自定义组件实例详解
2020/12/31 jQuery
python入门之语句(if语句、while语句、for语句)
2015/01/19 Python
在Django中管理Users和Permissions以及Groups的方法
2015/07/23 Python
pyCharm 设置调试输出窗口中文显示方式(字符码转换)
2020/06/09 Python
opencv 阈值分割的具体使用
2020/07/08 Python
Python os库常用操作代码汇总
2020/11/03 Python
挪威户外活动服装和装备购物网站:Bergfreunde挪威
2016/10/20 全球购物
C++:memset ,memcpy和strcpy的根本区别
2013/04/27 面试题
一道SQL面试题
2012/12/31 面试题
精彩的大学生自我评价
2013/11/17 职场文书
会计专业毕业自荐书范文
2014/02/08 职场文书
食品安全标语
2014/06/07 职场文书
大学生工作求职信
2014/06/23 职场文书
授权委托书样本
2014/09/25 职场文书
党支部组织生活会整改方案
2014/09/30 职场文书
2014年组织部工作总结
2014/11/14 职场文书
2016党员入党决心书
2015/09/22 职场文书
一波干货,会议主持词开场白范文
2019/05/06 职场文书
MySQL删除和插入数据很慢的问题解决
2021/06/03 MySQL
Python list列表删除元素的4种方法
2021/11/01 Python