Rumah hujung hadapan web tutorial js Analisis mendalam tentang fungsi kari dalam kemahiran JavaScript_javascript

Analisis mendalam tentang fungsi kari dalam kemahiran JavaScript_javascript

May 16, 2016 pm 03:02 PM
javascript fungsi Karipap

Asal usul kari ialah nama ahli matematik Haskell Curry (bahasa pengaturcaraan Haskell juga dinamakan sempena namanya).

Currying biasanya juga dipanggil penilaian separa, yang bermaksud menghantar parameter kepada fungsi langkah demi langkah, menggunakan sebahagian parameter selepas setiap laluan, dan mengembalikan fungsi yang lebih khusus untuk menerima parameter yang selebihnya Ini boleh bersarang berbilang peringkat seperti ini Fungsi menerima beberapa parameter sehingga hasil akhir dikembalikan.

Oleh itu, proses karipap adalah proses melepasi parameter secara beransur-ansur, secara beransur-ansur menyempitkan skop fungsi yang berkenaan, dan secara beransur-ansur menyelesaikan masalah.

Mengarut fungsi penjumlahan
Menurut penilaian langkah demi langkah, mari lihat contoh mudah

var concat3Words = function (a, b, c) { 
  return a+b+c; 
}; 
 
var concat3WordsCurrying = function(a) { 
  return function (b) { 
    return function (c) { 
      return a+b+c; 
    }; 
  }; 
}; 
console.log(concat3Words("foo ","bar ","baza"));      // foo bar baza 
console.log(concat3WordsCurrying("foo "));         // [Function] 
console.log(concat3WordsCurrying("foo ")("bar ")("baza")); // foo bar baza 
Salin selepas log masuk

Seperti yang anda lihat, concat3WordsCurrying("foo ") ialah Fungsi Setiap panggilan mengembalikan fungsi baharu, yang menerima panggilan lain dan kemudian mengembalikan fungsi baharu sehingga keputusan akhir dikembalikan, Kemajuan langkah demi langkah. (PS: Ciri-ciri penutupan digunakan di sini)

Jadi sekarang kita melangkah lebih jauh Jika kita memerlukan lebih daripada 3 parameter untuk dilalui, kita boleh lulus seberapa banyak parameter yang kita mahu Apabila tiada parameter yang diluluskan, hasilnya adalah output?

Mula-mula mari kita lakukan pelaksanaan biasa:

var add = function(items){ 
  return items.reduce(function(a,b){ 
    return a+b 
  }); 
}; 
console.log(add([1,2,3,4])); 
Salin selepas log masuk

Tetapi jika diperlukan untuk mendarab setiap nombor dengan 10 dan kemudian menambahnya, maka:

var add = function (items,multi) { 
  return items.map(function (item) { 
    return item*multi; 
  }).reduce(function (a, b) { 
    return a + b 
  }); 
}; 
console.log(add([1, 2, 3, 4],10)); 
Salin selepas log masuk

Nasib baik, terdapat fungsi peta dan pengurangan Jika kita mengikuti model ini dan kini menambah 1 pada setiap item dan kemudian meringkaskannya, maka kita perlu menggantikan fungsi dalam peta.

Mari kita lihat pelaksanaan kari:

var adder = function () { 
  var _args = []; 
  return function () { 
    if (arguments.length === 0) { 
      return _args.reduce(function (a, b) { 
        return a + b; 
      }); 
    } 
    [].push.apply(_args, [].slice.call(arguments)); 
    return arguments.callee; 
  } 
};   
var sum = adder(); 
 
console.log(sum);   // Function 
 
sum(100,200)(300);  // 调用形式灵活,一次调用可输入一个或者多个参数,并且支持链式调用 
sum(400); 
console.log(sum());  // 1000 (加总计算) 
Salin selepas log masuk

Penambah di atas ialah fungsi kari Ia mengembalikan fungsi baharu Fungsi baharu boleh menerima parameter baharu dalam kelompok dan menangguhkan pengiraan sehingga kali terakhir.

Fungsi kari universal

Kari yang lebih tipikal akan merangkumkan pengiraan terakhir ke dalam fungsi, dan kemudian menghantar fungsi ini sebagai parameter kepada fungsi kari, yang jelas dan fleksibel.

Sebagai contoh, jika setiap item didarab dengan 10, kita boleh lulus fungsi pemprosesan sebagai parameter:

var currying = function (fn) { 
  var _args = []; 
  return function () { 
    if (arguments.length === 0) { 
      return fn.apply(this, _args); 
    } 
    Array.prototype.push.apply(_args, [].slice.call(arguments)); 
    return arguments.callee; 
  } 
}; 
 
var multi=function () { 
  var total = 0; 
  for (var i = 0, c; c = arguments[i++];) { 
    total += c; 
  } 
  return total; 
}; 
 
var sum = currying(multi);  
  
sum(100,200)(300); 
sum(400); 
console.log(sum());   // 1000 (空白调用时才真正计算)
Salin selepas log masuk

Dengan cara ini, sum = currying(multi), panggilannya sangat jelas, dan kesan penggunaannya juga cemerlang Contohnya, jika anda ingin mengumpul berbilang nilai, anda boleh menggunakan berbilang nilai sebagai parameter sum(. 1,2,3), yang juga boleh disokong Panggilan berantai, jumlah(1)(2)(3)

Asas karipap

Kod di atas sebenarnya adalah fungsi tertib tinggi Fungsi tertib tinggi merujuk kepada fungsi yang beroperasi pada fungsi Ia menerima satu atau lebih fungsi sebagai parameter dan mengembalikan fungsi baharu. Selain itu, ia juga bergantung pada ciri-ciri penutupan untuk menyimpan parameter yang dimasukkan dalam proses perantaraan. Iaitu:

Fungsi boleh diluluskan sebagai parameter
Fungsi boleh digunakan sebagai nilai pulangan fungsi
Penutupan
Peranan karipap
Pengiraan tertangguh. Contoh di atas agak mudah untuk dijelaskan.

Penggunaan semula parameter. Apabila fungsi yang sama dipanggil beberapa kali dan parameter yang dilalui kebanyakannya sama, maka fungsi itu mungkin menjadi calon yang baik untuk kari.

Buat fungsi secara dinamik. Ini boleh dilakukan dengan menjana fungsi baharu secara dinamik untuk mengendalikan perniagaan berikutnya selepas mengira sebahagian keputusan, sekali gus menghapuskan pengiraan berulang. Atau anda boleh mencipta fungsi baharu secara dinamik dengan menggunakan sebahagian daripada subset parameter yang akan dihantar ke dalam fungsi panggilan kepada fungsi Fungsi baharu ini menyimpan parameter yang dihantar berulang kali (anda tidak perlu menghantarnya setiap kali pada masa hadapan). Contohnya, penyemak imbas acara menambah kaedah pembantu untuk acara:

 var addEvent = function(el, type, fn, capture) { 
   if (window.addEventListener) { 
     el.addEventListener(type, function(e) { 
       fn.call(el, e); 
     }, capture); 
   } else if (window.attachEvent) { 
     el.attachEvent("on" + type, function(e) { 
       fn.call(el, e); 
     }); 
   } 
 }; 
Salin selepas log masuk

Setiap kali anda menambah pemprosesan acara, anda perlu melaksanakan jika...selain itu.... Sebenarnya, hanya satu pertimbangan diperlukan dalam penyemak imbas Fungsi baharu dijana secara dinamik berdasarkan hasil satu pertimbangan, jadi tidak perlu berbuat demikian pada masa hadapan.

var addEvent = (function(){ 
  if (window.addEventListener) { 
    return function(el, sType, fn, capture) { 
      el.addEventListener(sType, function(e) { 
        fn.call(el, e); 
      }, (capture)); 
    }; 
  } else if (window.attachEvent) { 
    return function(el, sType, fn, capture) { 
      el.attachEvent("on" + sType, function(e) { 
        fn.call(el, e); 
      }); 
    }; 
  } 
})(); 
Salin selepas log masuk

Dalam contoh ini, selepas penghakiman if...else... yang pertama, sebahagian daripada pengiraan selesai dan fungsi baharu dicipta secara dinamik untuk memproses parameter yang dihantar kemudian.

Kaedah Function.prototype.bind juga merupakan aplikasi kari

Berbeza daripada pelaksanaan langsung kaedah panggilan/guna, kaedah bind menetapkan parameter pertama sebagai konteks pelaksanaan fungsi, dan parameter lain dihantar kepada kaedah panggilan secara bergilir-gilir (badan fungsi itu sendiri tidak dilaksanakan dan boleh dianggap sebagai pelaksanaan tertunda), dan Ciptaan Dinamik mengembalikan fungsi baharu, yang mematuhi ciri-ciri karipap.

var foo = {x: 888}; 
var bar = function () { 
  console.log(this.x); 
}.bind(foo);        // 绑定 
bar();           // 888 
Salin selepas log masuk

Berikut ialah simulasi fungsi bind mencipta dan mengembalikan fungsi baharu Dalam fungsi baharu, fungsi yang benar-benar menjalankan perniagaan terikat kepada konteks yang dihantar sebagai parameter sebenar dan pelaksanaan ditangguhkan. .

Function.prototype.testBind = function (scope) { 
  var fn = this;          //// this 指向的是调用 testBind 方法的一个函数, 
  return function () { 
    return fn.apply(scope); 
  } 
}; 
var testBindBar = bar.testBind(foo); // 绑定 foo,延迟执行 
console.log(testBindBar);       // Function (可见,bind之后返回的是一个延迟执行的新函数) 
testBindBar();            // 888 
Salin selepas log masuk

Di sini kita harus memberi perhatian kepada pemahaman ini dalam prototaip.

Artikel di atas adalah analisis mendalam tentang fungsi kari dalam JavaScript Ini semua kandungan yang dikongsi oleh editor saya harap ia dapat memberi anda rujukan, dan saya harap anda akan menyokong Script Home.

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Apr 25, 2024 pm 02:39 PM

Bahasa Go menyediakan dua teknologi penciptaan fungsi dinamik: penutupan dan refleksi. penutupan membenarkan akses kepada pembolehubah dalam skop penutupan, dan refleksi boleh mencipta fungsi baharu menggunakan fungsi FuncOf. Teknologi ini berguna dalam menyesuaikan penghala HTTP, melaksanakan sistem yang sangat boleh disesuaikan dan membina komponen boleh pasang.

Pertimbangan untuk susunan parameter dalam penamaan fungsi C++ Pertimbangan untuk susunan parameter dalam penamaan fungsi C++ Apr 24, 2024 pm 04:21 PM

Dalam penamaan fungsi C++, adalah penting untuk mempertimbangkan susunan parameter untuk meningkatkan kebolehbacaan, mengurangkan ralat dan memudahkan pemfaktoran semula. Konvensyen susunan parameter biasa termasuk: tindakan-objek, objek-tindakan, makna semantik dan pematuhan perpustakaan standard. Susunan optimum bergantung pada tujuan fungsi, jenis parameter, kemungkinan kekeliruan dan konvensyen bahasa.

Bagaimana untuk menulis fungsi yang cekap dan boleh diselenggara di Jawa? Bagaimana untuk menulis fungsi yang cekap dan boleh diselenggara di Jawa? Apr 24, 2024 am 11:33 AM

Kunci untuk menulis fungsi Java yang cekap dan boleh diselenggara ialah: pastikan ia mudah. Gunakan penamaan yang bermakna. Mengendalikan situasi khas. Gunakan keterlihatan yang sesuai.

Koleksi lengkap formula fungsi excel Koleksi lengkap formula fungsi excel May 07, 2024 pm 12:04 PM

1. Fungsi SUM digunakan untuk menjumlahkan nombor dalam lajur atau sekumpulan sel, contohnya: =SUM(A1:J10). 2. Fungsi AVERAGE digunakan untuk mengira purata nombor dalam lajur atau sekumpulan sel, contohnya: =AVERAGE(A1:A10). 3. Fungsi COUNT, digunakan untuk mengira bilangan nombor atau teks dalam lajur atau sekumpulan sel, contohnya: =COUNT(A1:A10) 4. Fungsi IF, digunakan untuk membuat pertimbangan logik berdasarkan syarat yang ditentukan dan mengembalikan hasil yang sepadan.

Perbandingan kelebihan dan kekurangan parameter lalai fungsi C++ dan parameter pembolehubah Perbandingan kelebihan dan kekurangan parameter lalai fungsi C++ dan parameter pembolehubah Apr 21, 2024 am 10:21 AM

Kelebihan parameter lalai dalam fungsi C++ termasuk memudahkan panggilan, meningkatkan kebolehbacaan dan mengelakkan ralat. Kelemahannya ialah fleksibiliti terhad dan sekatan penamaan. Kelebihan parameter variadic termasuk fleksibiliti tanpa had dan pengikatan dinamik. Kelemahan termasuk kerumitan yang lebih besar, penukaran jenis tersirat dan kesukaran dalam penyahpepijatan.

Apakah faedah fungsi C++ mengembalikan jenis rujukan? Apakah faedah fungsi C++ mengembalikan jenis rujukan? Apr 20, 2024 pm 09:12 PM

Faedah fungsi mengembalikan jenis rujukan dalam C++ termasuk: Peningkatan prestasi: Melewati rujukan mengelakkan penyalinan objek, sekali gus menjimatkan memori dan masa. Pengubahsuaian langsung: Pemanggil boleh mengubah suai secara langsung objek rujukan yang dikembalikan tanpa menugaskannya semula. Kesederhanaan kod: Lulus melalui rujukan memudahkan kod dan tidak memerlukan operasi penugasan tambahan.

Apakah perbezaan antara fungsi PHP tersuai dan fungsi yang telah ditetapkan? Apakah perbezaan antara fungsi PHP tersuai dan fungsi yang telah ditetapkan? Apr 22, 2024 pm 02:21 PM

Perbezaan antara fungsi PHP tersuai dan fungsi yang dipratentukan ialah: Skop: Fungsi tersuai terhad kepada skop definisinya, manakala fungsi yang dipratentukan boleh diakses di seluruh skrip. Cara mentakrifkan: Fungsi tersuai ditakrifkan menggunakan kata kunci fungsi, manakala fungsi yang dipratakrifkan ditakrifkan oleh kernel PHP. Lulus parameter: Fungsi tersuai menerima parameter, manakala fungsi yang dipratentukan mungkin tidak memerlukan parameter. Kebolehlanjutan: Fungsi tersuai boleh dibuat mengikut keperluan, manakala fungsi yang dipratentukan terbina dalam dan tidak boleh diubah suai.

Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai May 01, 2024 pm 06:39 PM

Pengendalian pengecualian dalam C++ boleh dipertingkatkan melalui kelas pengecualian tersuai yang menyediakan mesej ralat khusus, maklumat kontekstual dan melaksanakan tindakan tersuai berdasarkan jenis ralat. Tentukan kelas pengecualian yang diwarisi daripada std::exception untuk memberikan maklumat ralat tertentu. Gunakan kata kunci lontaran untuk membuang pengecualian tersuai. Gunakan dynamic_cast dalam blok try-catch untuk menukar pengecualian yang ditangkap kepada jenis pengecualian tersuai. Dalam kes sebenar, fungsi open_file membuang pengecualian FileNotFoundException Menangkap dan mengendalikan pengecualian boleh memberikan mesej ralat yang lebih spesifik.

See all articles