index.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. //Temperature
  2. //Оформите Temperature как функцию, в которую параметром передается температура в одной системе, а возвращается в другой. Никаких prompt и console.log в коде быть не должно, если вы хотите в дальнейшем пользоваться этой функцией где угодно в коде удобно. Нужен ли блок кода в функции для решения этой задачи?
  3. {
  4. const temperatureCtoF = c => c * 9/5 + 32;
  5. }
  6. /*RGB
  7. Оформите Number: RGB как функцию, в которую параметрами передаются три числа (r,g,b) => . Функция должна возвращать строку в нотации #RRGGBB. Используя условия или тернарный оператор добейтесь что бы в результате всегда было 7 символов, даже когда значение цвета меньше 15ти. Нужен ли блок кода этой функции?*/
  8. {
  9. const rgbToHex = (r,g,b) => {
  10. const hex = '#' +
  11. (r > 15 ? r.toString(16) : "0" + r.toString(16)) +
  12. (g > 15 ? g.toString(16) : "0" + g.toString(16)) +
  13. (b > 15 ? b.toString(16) : "0" + b.toString(16));
  14. return hex
  15. }
  16. console.log(rgbToHex(0,0,0))
  17. }
  18. /*Flats
  19. Оформите Number: flats как функцию. Продумайте достаточное количество параметров для решения задачи. Функция должна возвращать объект вида {entrance, floor}, где entrance - номер падика, floor - номер этажа на котором находится квартира.*/
  20. {
  21. const entranceAndFlor = (apartmentNumber, houseFloors, apartmentОnFloor) => {
  22. const apartmentOnFrontDoor = houseFloors * apartmentОnFloor;
  23. const apartmentNumberInFrontDoor = (apartmentNumber -1) % apartmentOnFrontDoor;
  24. const floor = Math.floor(apartmentNumberInFrontDoor/apartmentОnFloor)+1;
  25. const entrance = Math.ceil(apartmentNumber / apartmentOnFrontDoor);
  26. return result = {
  27. entrance,
  28. floor
  29. }
  30. }
  31. console.log(entranceAndFlor(36,9,4))
  32. }
  33. /*Credentials
  34. Оформите задание String: credentials как функцию без параметров. Используйте функцию capitalize из домашнего задания по массивам. Функция должна содержать вызовы prompt и возвращать объект вида {name, surname, fatherName, fullName}*/
  35. {
  36. const person = () => {
  37. let trimAndCapitalize = (str) => str.trim()[0].toUpperCase() + str.trim().slice(1).toLowerCase();
  38. let surname = trimAndCapitalize (
  39. prompt('введите вашу фамилию.\nMожете добавить пару пробелов в конце или начале. Написать с маленькой буквы или даже сделать пару букв в середине фамилии большими, я все поправлю!')
  40. );
  41. let name = trimAndCapitalize (
  42. prompt('введите ваше имя')
  43. );
  44. let fatherName = trimAndCapitalize (
  45. prompt('введите ваше отчество')
  46. );
  47. let fullName = surname + " " + name + " " + fatherName;
  48. return {
  49. name,
  50. surname,
  51. fatherName,
  52. fullName
  53. }
  54. }
  55. }
  56. /*New line
  57. Оформите задание String: new line как функцию с параметром-строкой. Функция должна возвращать строку с настоящими переносами. */
  58. {
  59. const stringNewline = (str) => str.split('\\n').join('\n')
  60. console.log( stringNewline('sdf\n\nsdf\nsdf') )
  61. }
  62. /*Prompt OR
  63. Оформите задание Prompt: OR как функцию, которая принимает строку для prompt и значение по умолчанию. Функция должна возвращать введенный текст или значение по умолчанию в случае отказа пользователя вводить что-либо. Используйте функцию без блока кода (функцию в одно выражение)*/
  64. //Prompt: or
  65. //Для задания Number: age используя ИЛИ || вывести сообщение об ошибке (alert) если пользователь не введет возраст или нажмет отмену (т. е. prompt выдаст пустую строку или null, интерпретируемую как false).
  66. {
  67. const promptOr = (promptStr, promptDefault) => prompt (promptStr) || promptDefault
  68. console.log( promptOr('введи что-то', 'ignore') )
  69. }
  70. /*Login And Password
  71. Оформите задание Login And Password как функцию, которая принимает два параметра - правильный логин и пароль и возвращает true если логин и пароль введенные пользователями верны, или false если пользователь не смог.*/
  72. //Login and password
  73. //Напишите код, который спрашивает логин, проверяет его на верность, в случае если логин верен, просит ввести пароль и проверяет его. В случае несовпадения логина или пароля выводить alert с текстом ошибки. В случае успешного логина - alert с поздравлением. Правильные логин: admin и пароль: qwerty. Используйте вложенные if и else.
  74. {
  75. const LoginAndPass = (loginTrue, passTrue) => {
  76. const login = prompt("login");
  77. if (login !== loginTrue){
  78. return false
  79. }else{
  80. const passs = prompt("pass");
  81. if (passs !== passTrue){
  82. return false;
  83. }else{
  84. return true
  85. }
  86. }
  87. }
  88. console.log(LoginAndPass("admin", "admin"))
  89. }
  90. /* For Table
  91. Оформите задание For Multiply Table как функцию, которая принимает любой массив с массивами, а возвращает строку HTML с тэгом <table> и всякими tr и td. */
  92. /* For Multiply Table
  93. Выведите таблицу умножения 5x5 из задания Multiply table в таблицу, используя вложенные for .... of и document.write
  94. Сделайте черезстрочную подсветку - задавайте четным строкам один цвет фона, нечетным - другой*/
  95. {
  96. const arr = [
  97. [0,0,0,0,0,0],
  98. [0,1,2,3,4,5],
  99. [0,2,4,6,8,10],
  100. [0,3,6,9,12,15],
  101. [0,4,8,12,16,20],
  102. [0,5,10,15,20,25]
  103. ];
  104. const arrToHtml = (arr) => {
  105. let str = "<table>"
  106. let i = 1
  107. for (let tr of arr){
  108. if (i++ % 2 === 0){
  109. str += '<tr style="background-color: grey;">'
  110. }else{
  111. str += "<tr>"
  112. }
  113. for (let td of tr){
  114. str += "<td>" + td + "</td>"
  115. }
  116. str += "</tr>"
  117. }
  118. str += "</table>"
  119. return (str)
  120. }
  121. console.log(arrToHtml(arr))
  122. }
  123. /*Filter Lexics
  124. Оформите задание Filter Lexics как функцию, принимающую любую строку для проверки и массив некорректных слов (['бляха', 'муха', "пляха", "шабля"], например). Функция должна возвращать строку без этих некорректных слов.*/
  125. /*Filter Lexics
  126. Пусть пользователь вводит строку. Разбейте её по пробелам. Используя filter верните true если элемент массива не состоит в определенном массиве недопустимых слов. Если же элемент массива - недопустимое слово, функция, переданная в filter должна возвращать false. Соберите массив в строку обратно.*/
  127. {
  128. let FilterLexics = (str, arrBadWords) => {
  129. let arr = str.split(" ");
  130. const f = (word) => {
  131. for (let BadWord of arrBadWords){
  132. if (word.toLowerCase() === BadWord.toLowerCase()){return false}
  133. }
  134. return true;
  135. }
  136. let arrNew = arr.filter(f);
  137. return arrNew.join(' ')
  138. }
  139. console.log(FilterLexics("ilter Lexics Оформите задание Filter Lexics как функцию, принимающую любую строку для проверки и массив некорректных слов бляха , муха , пляха, шабля, например). Функция должна возвращать строку без этих некорректных слов." , ['бляха', 'муха', 'пляха', 'шабля']))
  140. }
  141. /*Currency Table
  142. Оформите задание Currency Table как функцию, без параметров, которая складывает полученные данные во внутренний двумерный массив, после чего отображает его используя функцию из задания For Table*/
  143. /*Currency table
  144. Сделайте двумерную таблицу с курсами между всеми возможными парами валют по типу таблицы Пифагора, используя заготовку из задания Currency real rate:
  145. Используйте только один запрос на сервер. Используйте расчет кросскурса для вычисления курса между любой парой валют*/
  146. {
  147. const arrCurency = () =>{
  148. fetch('https://open.er-api.com/v6/latest/USD').then(res => res.json())
  149. .then(data => {
  150. const arrToHtml = (arrInner) => {
  151. let str = "<table>"
  152. let i = 1
  153. for (let tr of arrInner){
  154. if (i++ % 2 === 0){
  155. str += '<tr style="background-color: grey;">'
  156. }else{
  157. str += "<tr>"
  158. }
  159. for (let td of tr){
  160. str += "<td>" + td + "</td>"
  161. }
  162. str += "</tr>"
  163. }
  164. str += "</table>"
  165. document.write(str)
  166. }
  167. arr = [];
  168. let arrTh = ["",]
  169. for (let currency in data.rates){
  170. arrTh.push(currency)
  171. }
  172. arr.push(arrTh)
  173. for (let currencyStart in data.rates){
  174. let arrTr = []
  175. arrTr.push(currencyStart)
  176. for (let currencyFinish in data.rates) {
  177. arrTr.push(data.rates[currencyFinish] / data.rates[currencyStart])
  178. }
  179. arr.push(arrTr)
  180. }
  181. console.log(arr)
  182. arrToHtml(arr)
  183. })
  184. }
  185. arrCurency()
  186. }
  187. /*Form
  188. Оформите задание Form как функцию, которая принимает любой объект как параметр и создает форму на экране.*/
  189. {
  190. const car = {
  191. "Name":"chevrolet chevelle malibu",
  192. "Cylinders":8,
  193. "Displacement":307,
  194. "Horsepower":130,
  195. "Weight_in_lbs":3504,
  196. "Origin":"USA",
  197. "in_production": false
  198. }
  199. let objToForm = (obj) => {
  200. let form = '<form>'
  201. for (let label in obj){
  202. form += '<label>' + label +':';
  203. let type = typeof obj[label];
  204. let typeHtml
  205. if (type === "number") typeHtml = "number";
  206. if (type === "string") typeHtml = "text";
  207. if (type === "boolean") typeHtml = "checkbox";
  208. form += `<input type="${typeHtml}" value="${obj[label]}"/>`
  209. form += '</label>';
  210. }
  211. document.write(form)
  212. }
  213. objToForm(car)
  214. }
  215. /*Array of objects sort
  216. Сделайте обобщенную функцию сортировки массива с объектами
  217. var persons = [
  218. {name: "Иван", age: 17},
  219. {name: "Мария", age: 35},
  220. {name: "Алексей", age: 73},
  221. {name: "Яков", age: 12},
  222. ]
  223. sort(persons, "age"); //сортирует по возрасту по возрастанию
  224. sort(persons, "name", false); //сортирует по имени по убыванию
  225. Функция позволяет отсортировать любой набор данных по имени поля (второй параметр). Третьим параметром идет необязательный Boolean, который в случае true делает сортировку по возрастанию, в случае false - по убыванию. По умолчанию (без третьего параметра) происходит сортировка по возрастанию.
  226. Если параметр не задан - внутри функции он равен undefined
  227. */
  228. {
  229. var persons = [
  230. {name: "Иван", age: 17},
  231. {name: "Мария", age: 35},
  232. {name: "Алексей", age: 73},
  233. {name: "Яков", age: 12},
  234. ]
  235. // console.log(persons.sort((a,b) => a.name > b.name ? 1 : -1))
  236. const sortObjByProperty = (arrObj, objProperty, sortDirectionUp) => {
  237. if (sortDirectionUp) {
  238. direction1 = 1;
  239. direction2 = -1;
  240. }else if(sortDirectionUp === undefined){
  241. direction1 = 1;
  242. direction2 = -1;
  243. }else if(sortDirectionUp === false){
  244. direction1 = -1;
  245. direction2 = 1;
  246. }
  247. const sortObj = (a,b) => {
  248. if(a[objProperty] === undefined && b[objProperty] === undefined){
  249. return 0;
  250. }else if(a[objProperty] === undefined && b[objProperty]){
  251. return 1
  252. }else if(b[objProperty] === undefined && a[objProperty]){
  253. return -1
  254. }else{
  255. return a[objProperty] > b[objProperty] ? direction1 : direction2;
  256. }
  257. }
  258. arrObj.sort(sortObj);
  259. return arrObj
  260. }
  261. console.log(sortObjByProperty(persons, "name", false))
  262. }
  263. /* Table
  264. Оформите задание Table как функцию, которая принимает следующие параметры:
  265. любой массив объектов для отображения
  266. поле, по которому сортировать
  267. порядок сортировки (убывание/возрастание)
  268. Перед отображением:
  269. скопируйте исходный массив, что бы сортировка не изменила оригинал;
  270. отсортируйте с помощью функции из предыдущего задания
  271. Отображение возьмите из задания Table */
  272. {
  273. const persons = [
  274. {
  275. name: 'Мария',
  276. fatherName: 'Ивановна',
  277. surname: 'Иванова',
  278. sex: 'female'
  279. },
  280. {
  281. name: 'Николай',
  282. fatherName: 'Иванович',
  283. surname: 'Иванов',
  284. age: 15
  285. },
  286. {
  287. name: 'Петр',
  288. fatherName: 'Иванович',
  289. surname: 'Иванов',
  290. married: true
  291. },
  292. ]
  293. // этой функцией сортируем обьекты в массиве по одному из свойств (по колонке), тут же определяем сортировка вверх или вниз
  294. const sortObjByProperty = (arrObj, objProperty, sortDirectionUp) => {
  295. // тут пишим правило сортировки по параметру sortDirectionUp (если параметр любое значение равное true или параметр вовсе не задан (undefined) сортируем снизу вверх. если false - от большего к меньшему)
  296. if (sortDirectionUp || sortDirectionUp === undefined) {
  297. direction1 = 1;
  298. direction2 = -1;
  299. }else if(sortDirectionUp === false){
  300. direction1 = -1;
  301. direction2 = 1;
  302. }
  303. // тут описываем как сравнивать. Задаем правило считать большим или меньшим если значение свойства или само свойство не существует (undefined). Это нужно для кореектной сортировки пустых ячеек. Если ни одно из сравниваемых свойств не undefined просто сравниваем больше меньше.
  304. const sortObj = (a,b) => {
  305. if(a[objProperty] === undefined && b[objProperty] === undefined){
  306. return 0;
  307. }else if(a[objProperty] === undefined && b[objProperty]){
  308. return 1
  309. }else if(b[objProperty] === undefined && a[objProperty]){
  310. return -1
  311. }else{
  312. return a[objProperty] > b[objProperty] ? direction1 : direction2;
  313. }
  314. }
  315. arrObj.sort(sortObj);
  316. console.log(arrObj)
  317. }
  318. // этой функцией рисуем отсортированный массив обьектов
  319. const arrObjCopyToTableAndSort = (arrObj, objProperty, sortDirection) =>{
  320. //копируем переданный обьект, дабы не менять исходник
  321. let arrObjCopy = [...arrObj]
  322. //сортируем arrObjCopy внешней фунцией (массив обьектов, по какому свойству сортировать, необязательное направлнеие сортировки(если не задаано или true сортирует по возрасианию, если false по убыванию) )
  323. sortObjByProperty(arrObjCopy, objProperty, sortDirection)
  324. // пербираем все свойства отсортированых ранее обьекты. Добавляем их в новый массив свойств (колонки в таблице). Если такое свойство уже ранее было добавлнео, пропускаем его.
  325. let arrColumn = [];
  326. for ( let obj of arrObjCopy){
  327. for (let key in obj ){
  328. if ( !(arrColumn.includes(key)) ) {arrColumn.push(key)}
  329. }
  330. }
  331. // рисуем заголовок таблицы (первую строку) по массиву с колонками
  332. let table = '<table>';
  333. table += '<tr>'
  334. for (let th of arrColumn){
  335. table += '<th>' + th + '</th>'
  336. }
  337. table += '</tr>'
  338. // рисуем строки таблицы. Одна строка = одному обьекту из массива
  339. for ( let obj of arrObjCopy) {
  340. table += '<tr>';
  341. // далее идем по массиву с колонками и создаем ячейки внутри каждой строки
  342. for (column of arrColumn){
  343. table += '<td>'
  344. // если в обьекте есть ключ соответвующий названию колонки внтурь ячейки добавляем его значение. Если нет ячейка добавляется пустой
  345. if (obj[column]) { table += obj[column] }
  346. table += '</td>'
  347. }
  348. table += '</tr>';
  349. }
  350. table += '</table>'
  351. document.write(table)
  352. }
  353. arrObjCopyToTableAndSort (persons, 'married', false)
  354. }
  355. /* Divide
  356. Реализуйте задание Number: divide в HTML:
  357. <input type='number' id="firstNumber" />
  358. <input type='number' id="secondNumber" />
  359. <div id="divisionResult">
  360. текст в div
  361. </div>
  362. <script>
  363. const calcResult = () => {
  364. console.log(firstNumber.value, secondNumber.value, divisionResult.innerHTML)
  365. divisionResult.innerHTML = "Текст в <code>div</code> поменян с помощью <strong>Javascript</strong><br/>" + Math.random()
  366. }
  367. firstNumber.oninput = secondNumber.oninput = calcResult
  368. </script>
  369. Воспользуйтесь следующей информацией:
  370. все id в HTML становятся глобальными переменными (если это имя не занято, id="prompt" не сработает, функция prompt будет работать и далее);
  371. Любой DOM-элемент (то, что в HTML называется тэгом или парой тэгов) является объектом;
  372. Для доступа к атрибуту value тэгов input используется свойство value (например, firstNumber.value)
  373. Для доступа к вложенному тексту парных тэгов используется свойство innerHTML (например, divisionResult.innerHTML)
  374. Заготовка выше обеспечивает запуск функции calcResult по любому изменению текста в полях ввода. Напишите в ней деление значений из полей ввода и выведите результат в div. */
  375. {
  376. <body>
  377. <input type='number' id="firstNumber" />
  378. <input type='number' id="secondNumber" />
  379. <p id="ResultP"> первое число поместится во втором целых <span id="divisionResult">___</span> раз</p>
  380. <p id="Resultmodulo">тут будет остаток от деления ____</p>
  381. <script>
  382. const calcResult = () => {
  383. console.log(firstNumber.value, secondNumber.value, divisionResult.innerHTML)
  384. divisionResult.innerHTML = Math.floor(Math.abs(firstNumber.value) / Math.abs(secondNumber.value));
  385. const modulo = Math.abs(firstNumber.value) % Math.abs(secondNumber.value);
  386. Resultmodulo.innerHTML = 'Остаток: ' + modulo.toFixed(3)
  387. }
  388. firstNumber.oninput = secondNumber.oninput = calcResult
  389. </script>
  390. </body>
  391. }
  392. /* Calc Func
  393. Вспомните первое ДЗ по Javascript, в котором вы делали всякие расчеты используя код на Javascript. Оформите это как функцию:
  394. найдите все входящие данные, сделайте из них параметры
  395. найдите переменную с результатом расчетов и сделайте так, что бы ваша функция возвращала этот результат.
  396. Если результатов несколько, создайте объект из этих результатов и верните его. */
  397. {
  398. /*let bikes = prompt ('сколько велосипедов вам нужно', '1');
  399. let bikesCategory = prompt ('укажите категорию велосипедов');
  400. const bikesCost = 80;
  401. let timeRent = prompt ('Стоимость одного часа 80 грн. Укажите цифрами сколько часов аренды?');
  402. let costResult = bikes * bikesCost * timeRent;
  403. confirm ('Давайте проверим всё ли правильно! \n количество велосипедов: ' + bikes + '\n Выбранная категория: ' + bikesCategory + '\n Время аренды ' + timeRent + ' часов \n ИТОГОВАЯ СТОИМОСТЬ: ' + costResult + 'грн \n Всё верно?')*/
  404. let bikeRentCalculator = (bikes, bikesCategory, bikesCost, timeRent) => {
  405. let costResult = bikes * bikesCost * timeRent;
  406. return {
  407. bikes,
  408. bikesCategory,
  409. bikesCost,
  410. timeRent,
  411. costResult,
  412. }
  413. }
  414. }
  415. /*Calc Live
  416. Используя пример из задания Divide и функцию из Calc Func сделайте несколько полей ввода в HTML, меняя которые вы будете получать результат калькуляции в каком-то div.*/
  417. {
  418. <body>
  419. <p>Количество велосипедов: <input type='number' id="bikes" /></p>
  420. <p>Категория велосипедов: <input type='number' id="bikesCategory" /></p>
  421. <p>Часов арнеды (стоимость 80грн/час): <input type='number' id="timeRent" /></p>
  422. <br></br>
  423. <p id="result" style = "background: green; padding: 20px 10px; color: white">тут появится цена когда вы заполните все ячейки</p>
  424. <script>
  425. const calcResult = () => {
  426. let bikesCost = 80;
  427. result.innerHTML = bikes.value * timeRent.value * bikesCost + ' грн'
  428. }
  429. bikes.oninput = timeRent.oninput = calcResult
  430. </script>
  431. </body>
  432. }