index.html 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <script>
  11. //MAKEPROFILETIMER
  12. // let makeProfileTimer = () => {
  13. // let startTime = performance.now();
  14. // return () => performance.now() - startTime;
  15. // };
  16. // var timer = makeProfileTimer();
  17. // alert("Замеряем время работы этого alert"); //некий код, время выполнения которого мы хотим измерить с высокой точностью
  18. // alert(timer());
  19. //MAKESAVER
  20. // let makeSaver = (cb) => {
  21. // let someVariableToSave;
  22. // return () => {
  23. // if (someVariableToSave === undefined) {
  24. // someVariableToSave = cb();
  25. // }
  26. // return someVariableToSave;
  27. // };
  28. // };
  29. // var saver = makeSaver(Math.random);
  30. // var value1 = saver(); //saver вызывает переданную в makeSaver функцию, запоминает результат и возвращает его
  31. // var value2 = saver(); //saver в дальнейшем просто хранит результат функции, и более НЕ вызывает переданную
  32. // //в makeSaver функцию;
  33. // console.log(value1 === value2); // всегда true
  34. // var saver2 = makeSaver(
  35. // () =>
  36. // console.log("saved function called") ||
  37. // [null, undefined, false, "", 0, Math.random()][Math.ceil(Math.random() * 6)]
  38. // );
  39. // var value3 = saver2();
  40. // var value4 = saver2();
  41. // console.log(value3 === value4); // тоже должно быть true
  42. // let namePrompt = prompt.bind(window, "Как тебя зовут?");
  43. // let nameSaver = makeSaver(namePrompt);
  44. // alert(`Привет! Prompt еще не было!`);
  45. // alert(`Привет ${nameSaver()}. Только что запустился prompt, первый и последний раз`);
  46. // alert(`Слушай, ${nameSaver()}, го пить пиво. Ведь prompt был только один раз`);
  47. //FINAL COUNTDOWN
  48. // (() => {
  49. // let num = 5;
  50. // for (let i = num; i > 0; i--) {
  51. // setTimeout(() => console.log(i), i * 1000);
  52. // i === num && setTimeout(() => console.log("поехали!"), (num + 1) * 1000);
  53. // }
  54. // })();
  55. //MYBIND
  56. // let myBind = (cb, that, paramsToBind = []) => {
  57. // return (...params) => {
  58. // let rezParams = paramsToBind.map((el, idx) => {
  59. // if (el === undefined) {
  60. // el = params[0];
  61. // params.shift();
  62. // }
  63. // return el;
  64. // });
  65. // rezParams = [...rezParams, ...params];
  66. // return cb.call(that, ...rezParams);
  67. // };
  68. // };
  69. // var pow5 = myBind(Math.pow, Math, [undefined, 5]); // первый параметр - функция для биндинга значений по умолчанию,
  70. // // второй - this для этой функции, третий - массив, в котором undefined означает
  71. // // параметры, которые должны передаваться при вызове,
  72. // // а другие значения являются значениями по умолчанию:
  73. // var cube = myBind(Math.pow, Math, [undefined, 3]); // cube возводит число в куб
  74. // console.log(pow5(2)); // => 32, вызывает Math.pow(2,5), соотнесите с [undefined, 5]
  75. // console.log(cube(3)); // => 27
  76. // var chessMin = myBind(Math.min, Math, [undefined, 4, undefined, 5, undefined, 8, undefined, 9]);
  77. // chessMin(-1, -5, 3, 15); // вызывает Math.min(-1, 4, -5, 5, 3, 8, 15, 9), результат -5
  78. // var zeroPrompt = myBind(prompt, window, [undefined, "0"]); // аналогично, только теперь задается "0" как текст по умолчанию в prompt,
  79. // // а текст приглашения пользователя задается при вызове zeroPrompt
  80. // var someNumber = zeroPrompt("Введите число"); // вызывает prompt("Введите число","0")
  81. // console.log(
  82. // myBind((...params) => params.join(""), null, [undefined, "b", undefined, undefined, "e", "f"])(
  83. // "a",
  84. // "c",
  85. // "d"
  86. // ) === "abcdef"
  87. // );
  88. </script>
  89. </body>
  90. </html>