<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • javascript之Function對象學習小結

    時間:2024-07-21 06:31:39 JavaScript 我要投稿
    • 相關推薦

    javascript之Function對象學習小結

      1、Function 函數調用(類似call方法)

    javascript之Function對象學習小結

      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之Function對象學習小結】相關文章:

    javascript面向對象中的對象怎么理解09-02

    javascript克隆對象深度介紹07-25

    JavaScript中的三種對象10-24

    使用ajax操作JavaScript對象的方法09-28

    JavaScript學習筆記08-24

    關于javascript對象之內置和對象Math的使用方法10-08

    IE與Firefox在JavaScript上的不同寫法小結07-22

    JavaScript高級程序設計:本地對象Array10-22

    Javascript中arguments對象的詳解和使用方法08-20

    常用排序算法之JavaScript實現代碼段06-04

    主站蜘蛛池模板: 亚洲精品视频免费观看| 野狼精品社区| 亚洲欧美精品SUV| 国产精品部在线观看| 精品亚洲成AV人在线观看| 国内精品欧美久久精品| 国产成人久久精品区一区二区| 亚洲人成国产精品无码| 国产高清在线精品一本大道| 国产精品乱码高清在线观看| 亚洲精品乱码久久久久久蜜桃| 国产精品视频色视频| 国产欧美国产精品第一区| 国产日韩精品在线| 亚洲高清国产拍精品26U| 精品日韩欧美国产| 亚洲国产精品欧美日韩一区二区 | 无码人妻精品一区二区三区在线 | 久久青青草原精品国产| 乱码精品一区二区三区| 久久亚洲中文字幕精品一区| 国产成人1024精品免费| 日韩精品一区二三区中文| 影音先锋国产精品国语对白| 国产精品白丝AV网站| 国产乱人伦偷精品视频AAA| 久久综合精品国产二区无码| 亚洲日韩精品射精日| 在线亚洲精品福利网址导航| 亚欧乱色国产精品免费视频| 人妻精品久久久久中文字幕| 麻豆国产在线精品国偷产拍 | 久久久久无码精品国产不卡| 中国国产精品| 亚洲国产小视频精品久久久三级| 久久国产成人亚洲精品影院 | 99爱在线视频这里只有精品 | 亚洲精品成人片在线播放| 综合在线视频精品专区| 在线精品亚洲一区二区小说| 中文字幕精品视频在线|