123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- $(document).ready(function() {
- $(".button").css({ // Стилизация кнопки для запуска задач
- "display": "inline-block",
- "background": "grey",
- "cursor": "pointer",
- "padding": "10px",
- "margin": "20px 0 0 20px",
- "border-radius": "10px",
- "color": "white"
- });
- $(".task").css({
- "width": "50%",
- "border-bottom": "1px solid black",
- "box-sizing": "border-box",
- "padding": "10px"
- });
- $("div.task:nth-child(11)").append("<img>"); // Задание 11, добавить картинку
- $("div.task:nth-child(11) img").attr(image);
- });
-
- // Задачки
- function exercises(par) {
- var arr = [task_1, task_2, task_3, task_4, task_5, task_6, task_7, task_8, task_9];
-
- arr[par-1]();
- };
- // 1. Создайте смешанный массив, например [1, 2, 3, ‘a’, ‘b’, ‘c’, ‘4’, ‘5’, ‘6’].
- // Посчитайте сумму всех его чисел, включая строковые. Выведите сумму в alert.
- function task_1() {
- var arr = [1, 2, 3, 'a', 'b', 'c', '4', '5', '6'],
- sum = 0;
- for(var i = 0; i < arr.length; i++) {
- if (!isNaN(+arr[i])) {
- sum = sum + +arr[i];
- }
- }
- alert(sum);
- }
- // 2. Сгенерируйте массив из N случайных чисел с двумя знаками после запятой.
- // Затем переберите массив и распечатайте в консоли значения его элементов,
- // возведенные в пятую степень, используя вложенные циклы.
- function task_2() {
- var n = +prompt("Введите длинну массива", ""),
- arr = [];
- for(var i = 0; i < n; i++) {
- var a = 1; // переменная в которую будет записываться произведение элементов массива до 5-ой степени.
- arr[i] = (Math.random()*10).toFixed(2);
- for(var j = 0; j < 5; j++) {
- a = a * arr[i];
- }
- console.log(a);
- }
- console.log(arr);
- }
- // 3. Создайте пустой массив. В цикле до n на каждой итерации запускайте prompt для ввода любых символов,
- // полученное значение добавляйте в конец созданного массива. После выхода из цикла
- // посчитайте сумму всех чисел массива и выведите в alert полученный результат.
- function task_3() {
- var arr = [],
- sum = 0,
- n = prompt("Введите n", "");
- for(var i = 0; i < n; i++) {
- arr.push(prompt("Введите элемент массива", ''));
- }
- for(var j = 0; j < arr.length; j++) {
- if (!isNaN(+arr[j])) {
- sum = sum + +arr[j];
- }
- }
- alert(sum);
- }
- // 4. Создайте массив со значениями: ‘AngularJS’, ‘jQuery’
- // Добавьте в начало массива значение ‘Backbone.js’
- // Добавьте в конец массива значения ‘ReactJS’ и ‘Vue.js’
- // Добавьте в массив значение ‘CommonJS’ вторым элементом
- // Найдите и удалите из массива значение ‘jQuery’, выведите его в alert со словами “Это здесь лишнее”
- // ET = 8 min;
- // AT = 5 min;
- function task_4() {
- var arr = ['AngularJS', 'jquery'];
- arr.unshift('Backbobe.js');
- arr.push('ReactJS', 'Vue.js');
- arr.splice(1,0,'CommonJS');
- alert( arr.splice(arr.indexOf('jquery'), 1) + " - это здесь лишнее" );
- alert(arr);
- }
- // 5. Создайте строку с текстом ‘Как однажды Жак звонарь сломал городской фонарь’.
- // Разбейте ее на массив слов, и переставьте слова в правильном порядке с помощью любых
- // методов массива (indexOf, splice ...). Затем объедините элементы массива в строку
- // и выведите в alert исходный и итоговый варианты.
- // ET = 5 min;
- // AT = 9 min;
- function task_5() {
- var str_1 = "Как однажды Жак звонарь сломал городской фонарь",
- str_2,
- arr = [];
- arr = str_1.split(" ");
- arr.splice(arr.indexOf("городской"), 0, arr.splice(arr.indexOf("сломал"), 1));
- str_2 = arr.join(" ");
- alert(str_1+"\n"+str_2);
- }
- // 6. Используя вложенные циклы, сформируйте двумерный массив, содержащий таблицу умножения
- function task_6() {
- var arr = [];
- for(var i = 1; i <=10; i++) {
- arr[i] = [];
- for(var j = 1; j <= 10; j++) {
- arr[i][j] = i + "x" + j + "=" + (i*j);
- }
- }
- alert(arr);
- }
- // 7. Создайте ассоциативный массив person, описывающий персону, с произвольным
- // количеством произвольных полей. С помощью оператора in или typeof проверьте наличие
- // в объекте свойства, прочитанного из prompt, и выведите его на экран.
- // Если свойства нет, то добавляйте его в объект со значением, которое также запрашивается из prompt.
- function task_7() {
- var person = {
- name: "Oleg",
- age: 24,
- },
- a;
- a = prompt("Введите свойство объекта", "");
- if (a in person) {
- alert(a + ": " + person[a]);
- } else {
- person[a] = prompt("Такого поля нет. Давайте добавим поле " + a + ". Введите значение этого свойства:", "");
- alert(a + ": " + person[a])
- }
- }
- // 8. Сгенерируйте объект, описывающий модель телефона, заполнив все свойства значениями,
- // прочитанными из prompt (например: brand, model, resolution, color...), не используя
- // вспомогательные переменные. Добавьте этот гаджет персоне, созданной ранее.
- function task_8() {
- var person = {
- firstname: "Oleg",
- age: 24,
- },
- phone = {};
- alert("Давайте добавим свойства телефону");
- while(true) {
- var a = prompt("Введите характеристику телефона (например: brand, model, resolution, color...):");
- if (a == null || a == "") { // характеристики вводятся пока не будет нажата Отмена или введена пустая строка
- break;
- } else
- if (a in phone) {
- alert(a + ": " + phone[a]);
- } else {
- phone[a] = prompt("Такой характеристики нету. Давайте добавим " + a + ". Введите значение этого свойства:", "");
-
- }
- }
- person.personPhone = phone;
- }
- // 9. Создайте объект dates для хранения дат. Первая дата – текущая, new Date.
- // Вторая дата – текущая дата минус 365 дней. Из prompt читается дата в формате yyyy-MM-dd.
- // Проверьте, попадает ли введенная дата в диапазон дат объекта dates.
- function task_9() {
- var dates = {
- currentDate: new Date(),
- },
- userDate = prompt("Введите дату в формате yyyy-MM-dd", ""),
- arr = [];
- arr = userDate.split("-");
- var a = new Date(arr[0], arr[1] - 1, arr[2]);
- dates.secondDate = new Date(dates.currentDate - 365*24*60*60*1000);
-
- if (a > dates.secondDate && a < dates.currentDate) {
- alert("Введенная дата попадает в диапазон");
- } else {
- alert("Введенная дата не попадает в диапазон");
- }
- }
- // 10. Создайте структуру данных, полностью описывающую html-разметку картинки
- var image = {
- src: "https://www.google.com.ua/logos/doodles/2017/bella-akhmadulinas-80th-birthday-5134676388741120.3-law.gif",
- alt: "",
- style: {
- border: "1px solid #ccc"
- },
- width: 200
- }
- // 11. С помощью jQuery добавьте картинку на страницу вместе со всеми атрибутами, используя созданную ранее структуру.
- // Решение вверху
|