JS学习之函数定义与参数

功能

作为第一类对象,函数和JS中其他对象一样,类似于其对象类型,函数具有以下功能:

  • 通过字面量创建
function fun1() { }
  • 赋值给变量、数组项或其他对象的属性
// 为变量赋值一个新函数
let v1 = function fun2() { };

// 向数组中增加一个函数
let arr1 = [];
arr1.push(function () { });

// 给对象的属性赋值为一个新函数
let obj1 = {};
obj1.name = function () {};
  • 作为函数的参数来传递
function fun2(test) {
    test();
}
fun2(function () { });
  • 作为函数的返回值
function fun3() {
    return function () {};
}
  • 具有动态创建和分配的属性
let v2 = function () {};
v2.name = "test";
  • 回调函数是被代码随后“回来调用”的函数,它是一种很常用的函数,特别是在事件处理场景下
let button = document.getElementById("callback");
button.addEventListener("click", function () {
    console.log("button 点击了!");
});
  • 函数具有属性,而且这些属性能够被存储任何信息,我们可以利用这个特性来做很多事情
// 可以在函数属性中存储另一个函数,用于之后的引用和调用
let store = {
      nextId: 1,
      cache: {},
      add: function (fn) {
          // 仅当函数唯一时才将该函数加入缓存
          if (!fn.id) {
              fn.id = this.nextId++;
              this.cache[fn.id] = fn;
              return true;
          } else {
              return false;
          }
      }
};

function fun4() {}
console.log(store.add(fun4));// true
console.log(store.add(fun4)); // false


// 可以用函数属性创建一个缓存(记忆),用于减少不必要的计算
function f5(value) {
      // 计算某个数是否是素数
      if (!f5.answers) {
          // 给函数创建一个缓存对象属性
          f5.answers = {};
      }
      // 检查value是否已在缓存对象中
      if (f5.answers[value] !== undefined) {
          return f5.answers[value];
      }
      // 前提条件该value不能是0和1,因为这两个数不是素数
      let isPrime = value !== 0 && value !== 1;
      for (let i = 2; i < value; i++) {
          if (value % i === 0) {
              isPrime = false;
              break;
          }
      }
      return f5.answers[value] = isPrime;
}
console.log(f5(5)); // true
console.log(f5.answers[5]); // true

函数定义方式

  • 函数声明
function f6() {}
  • 函数表达式
// 作为赋值表达式的右值
let v6 = function () {};
// 作为其它函数的参数
f6(function () {});
// 作为函数返回值
function f7() {
    return function () {};
}
  • 立即函数。JS引擎解析到时会马上执行函数
+function () {console.log("立即函数");}();
-function () {}();
!function () {}();
~function () {}();
(function () {})();
  • 箭头函数
let arr2 = [0, 3, 2, 5, 4, 8, 1];
arr2.sort((value1, value2) => value1 - value2);
  • 函数构造函数
console.log(new Function("a", "b", "return a + b")(1, 2));
  • 生成器函数
function* myGen() {
      yield 10;
      y = yield "foo";
      yield y;
}

let gen = myGen();
console.log(gen.next());// {value: 10, done: false}
console.log(gen.next());// {value: "foo", done: false}
// 第二次函数调用时,遇到yield就把值返回了,并未给y赋值
console.log(gen.next());// {value: undefined, done: false}
console.log(gen.next());// {value: undefined, done: true}

函数参数

  • 剩余参数
// 不与任何形参名相匹配的额外实参可能通过剩余参数来引用
function f8(value, ...restParam) {
    for (let i = 0; i < restParam.length; i++) {
        console.log(`剩余参数:${restParam[i]}`);// 2,3,4
    }
}
f8(1, 2, 3, 4);
  • 默认参数
function f9(name, action = "舞蹈") {
    console.log(`${name}喜欢${action}`)
}

f9("Lily");// Lily喜欢舞蹈
f9("Jack", "蓝球");// Jack喜欢蓝球
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339

推荐阅读更多精彩内容