index.html 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>Замыкание</title>
  6. </head>
  7. <body>
  8. <script>
  9. //---------makeProfileTimer
  10. function makeProfileTimer(){
  11. let time1=performance.now();
  12. return function(){
  13. let time2=performance.now();
  14. return time2-time1;
  15. //alert(time2-time1);
  16. }
  17. }
  18. /*function fib(n){
  19. if(n==1||n==2){
  20. return 1;
  21. }else{
  22. return fib(n-1)+fib(n-2);
  23. }
  24. }*/
  25. var timer=makeProfileTimer();
  26. alert('Замеряем время работы этого alert');
  27. //alert(fib(10));
  28. alert(timer());
  29. //-----------makeSaver
  30. function makeSaver(fn){
  31. let x=fn();
  32. return function(){
  33. return x;
  34. }
  35. }
  36. var saver = makeSaver(Math.random);
  37. var value1 = saver();
  38. var value2 = saver();
  39. console.log(value1+" "+value2);
  40. console.log(value1 === value2);
  41. var saver2 = makeSaver(() => console.log('saved function called') || [null, undefined, false, '', 0, Math.random()][Math.ceil(Math.random()*6)]);
  42. var value3 = saver2();
  43. var value4 = saver2();
  44. console.log(value3 === value4);
  45. let namePrompt = prompt.bind(window, 'Как тебя зовут?')
  46. let nameSaver = makeSaver(namePrompt)
  47. alert(`Привет! Prompt еще не было!`)
  48. alert(`Привет ${nameSaver()}. Только что запустился prompt, первый и последний раз`)
  49. alert(`Слушай, ${nameSaver()}, го пить пиво. Ведь prompt был только один раз`)
  50. //-----------Final Countdown
  51. (function count(){
  52. let x=5;
  53. let y=setInterval(function(){
  54. console.log(x);
  55. if(x==1){
  56. clearInterval(y);
  57. console.log('поехали');
  58. }
  59. x--;
  60. },1000)
  61. })();
  62. //------------myBind
  63. function myBind(fn,context,args){
  64. /*return function(){
  65. let args2=Object.assign(args,arguments);
  66. return fn.call(context,...args2);
  67. }*/
  68. let arr=[...args];
  69. return function(){
  70. let arr2=Array.from(arguments);
  71. for(let i=0;i<arr.length;i++){
  72. if(!arr[i]){
  73. arr[i]=arr2.shift();
  74. }
  75. }
  76. return fn.call(context,...arr);
  77. }
  78. }
  79. var pow5 = myBind(Math.pow, Math, [undefined, 5]);
  80. var cube = myBind(Math.pow, Math, [undefined, 3]);
  81. console.log(pow5(2)); //32
  82. console.log(cube(3)); //27
  83. var chessMin = myBind(Math.min, Math, [undefined, 4, undefined, 5,undefined, 8,undefined, 9]);
  84. console.log(chessMin(-1,-5,3,15)); //-5
  85. var zeroPrompt = myBind(prompt, window, [undefined, "0"]);
  86. var someNumber = zeroPrompt("Введите число");
  87. console.log(someNumber);
  88. console.log(myBind((...params) => params.join(''), null, [undefined, 'b', undefined, undefined, 'e', 'f'])('a','c','d') === 'abcdef'); //true
  89. </script>
  90. </body>
  91. </html>