Jump to content
  • 0

Задачка JS


Schamil74
 Share

Question

23 answers to this question

Recommended Posts

  • 0

И новая задачка)))

Уже битый час сижу и не могу сложить два куска кода во единый. Или вообще неправильно мыслю?

Дан массив с числами. Числа могут быть положительными и отрицательными. Найдите сумму положительных элементов массива.

 

Выбирает положительные числа

var num = [4, -1, 2, 5, -8, -5, 9, -4];
for(var i = 0; i < num.length; i++) {
    if (num > 0) {
        var plus = num;
    }
}

 

Сумма положительных чисел

var sum = 0;
for (var j = 0; j < plus.length; j++) {
    sum += plus[j];
}
console.log(sum);

 

 

Link to comment
Share on other sites

  • 0
var num = [4, -1, 2, 5, -8, -5, 9, -4];

function sumNum(arr) {
  var primer = '';
  var sum = 0;

  for(var i = 0; i < arr.length; i++) {
    if(arr[i] > 0) {
      sum = sum + arr[i];
      primer = primer + arr[i] + '+';
    }
  }
  primer = primer.substring(0, primer.length - 1)
	
  return primer + '=' + sum;
}

console.log(sumNum(num))

 

Edited by DivMan
  • Like 1
Link to comment
Share on other sites

  • 0

Нужно было уточнить, сам виноват, что решение должно быть без функции и сложных махинаций, в рамках if-else-for-while.

Но все равно спасибо. Закидали ответами)))

Edited by Schamil74
Link to comment
Share on other sites

  • 0
6 часов назад, Svetlana_P сказал:

Извиняюсь, что влезаю без хорошего знания JS, но любопытно самой)

работать то работает,  но слишком много кода.   если делать через цикл, то можно и одним ограничится

Link to comment
Share on other sites

  • 0
5 часов назад, Николя223 сказал:

работать то работает,  но слишком много кода.   если делать через цикл, то можно и одним ограничится

Вот так? https://jsfiddle.net/fhuj82tv/2/

  • Like 1
Link to comment
Share on other sites

  • 0
11 минуту назад, andrey7287 сказал:

bad pratice, да и зачем ..

не согласен) фильтры фильтрами, но перебор массивов мне нужен часто. другое дело что я не часто использую нативный JS =)

тем более что в данном случае речь идет о цикле for  ) есть ещё foreach, но вот его то как раз я вообще не использую

Link to comment
Share on other sites

  • 0

 

13 минуты назад, Николя223 сказал:

не согласен)

Да пожалуйста. Метод некорректно обрабатывает разряженные массивы и перебирает свойства прототипа. Когда споткнётесь, тогда согласитесь -) 

21 минуту назад, Николя223 сказал:

тем более что в данном случае речь идет о цикле for  ) есть ещё foreach, но вот его то как раз я вообще не использую

Если так нравится императивный подход, используйте for of, 2017 год на дворе. 

Link to comment
Share on other sites

  • 0
1 час назад, andrey7287 сказал:

разряженные массивы

а как часто ты перебираешь в JS разреженные массивы? )  на стороне сервера это одно, на стороне клиента -  совершенно другое. тут больше вопрос как они в клиент попали 
upd :  если память не изменяет, в JS такие массивы должны представлять собой объект.  проверил в эмуляторе IE 8 даже перебирает) 

1 час назад, andrey7287 сказал:

Когда споткнётесь, тогда согласитесь

скажем так - я много на чем спотыкался и  выносил тот или иной урок)   речь идет о конкретном примере  

for of )  допустим в данном примере эта конструкция работает, а как быть если нужен индекс или же изменить значение массива на какое то другое?   =) 

но спорить особо не вижу смысла) так как не верстальщик )

Link to comment
Share on other sites

  • 0
16 часов назад, Николя223 сказал:

upd :  если память не изменяет, в JS такие массивы должны представлять собой объект.  проверил в эмуляторе IE 8 даже перебирает) 

Любой массив объект. Речь шла про то что вы не получите элементы когда они undefined.

var arr = [];
arr[6] = true;
16 часов назад, Николя223 сказал:

а как быть если нужен индекс

Как угодно, кроме for in -))) Он перечислимые свойства объекта отдаёт а не индексы массива (который в свою очередь тоже объект, ога ;) ) -))) Вот тебе строчка, которая поломает все твои итерации -) 

Array.prototype.test;

То что они в большинстве случаев совпадают и JS прощает подобные действие вовсе не означает что делать так хорошая идея. Почитай на досуге 

https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/Statements/for...in 

Edited by andrey7287
Link to comment
Share on other sites

  • 0
21 час назад, andrey7287 сказал:

Любой массив объект. Речь шла про то что вы не получите элементы когда они

эмм не согласен. если массив оформлен именно как объект, то он легко перебирается. попробуй.   

var arr = {};
arr[6] = true;

то что ниже - зависит от ситуаций)) Меня на JS можно подловить)) но на решениях его багов и неоднозначных проблемм - собаку съел)) несмотря на то, что больше практики на других языках) 

21 час назад, andrey7287 сказал:

Вот тебе строчка, которая поломает все твои итерации -) 

кстати не поленился проверить твои разреженные массивы - перебирает нормально)  а вот с прототипом - тут да. 

Link to comment
Share on other sites

  • 0

А вы все еще спорите)))

Лучше помогите правильно решить задачку

Нужно последнюю букву 't', сделать заглавной используя строковые функции без циклов. У меня хрень какая-то.

var str = 'lorem ipsum dolor sit amet.';
var letter = str.substr(-2,1).toUpperCase();
var find = str.lastIndexOf('t');
var result = str.replace(str[find], letter);
console.log(result);

Link to comment
Share on other sites

  • 0

Почитай документацию.   там пишут что нельзя просто так взять и заменить букву в строке по индексу. нужно создать новую строку

result = str.slice(0, find) + letter + str.slice(find + 1)

upd: может регулярками и возможно

upd2: replace по умолчанию заменит первое вхождение.  

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

  • Similar Content

    • By Kaido
      Использую готовый плагин для модальных окон(от MaxGraph). Проблема в том, что когда у меня открыто два модальных окна, для примера Форма + Политика конфендициальности, и мне нужно закрыть политику вместе с ней закрывается и другое модальное окно. В JS я не сильно разбираюсь(собственно из за этого и использую готовый плагин), можете помочь кто работал с этим плагином? Я примерно понимаю как он работает, но реализовать чтобы закрывалось только одно не получается.
       
        <div class="content"> <button class="modal-btn" data-path="first" data-animation="fadeInUp" data-speed="1500">Открыть окно 1</button> </div> <div class="modal"> <div class="modal__wrapp" data-target="first"> <div class="modal__content"> <button class="modal__close">Закрыть</button> модальное окно <button data-path="policy">Политика</button> </div> </div> <div class="modal__wrapp" data-target="policy"> <div class="modal__content"> <button class="modal__close">Закрыть</button> политика </div> </div> </div> .modal { --transition-time: 0.3s; position: fixed; left: 0; top: 0; right: 0; bottom: 0; z-index: 1000; cursor: pointer; overflow-y: auto; overflow-x: hidden; text-align: center; opacity: 0; visibility: hidden; transition: opacity var(--transition-time), visibility var(--transition-time); } .modal__wrapp { display: none; cursor: default; width: fit-content; height: fit-content; } .modal__content{ position: absolute; left: 500px; width: 500px; height: 500px; display: flex; color: white; flex-direction: column; text-align: left; background-color: #000; } .modal__content button{ width: 200px; height: 50px; margin: 50px 0; } .modal.is-open { opacity: 1; visibility: visible; transition: opacity var(--transition-time), visibility var(--transition-time); } .modal__wrapp.modal-open { display: flex; } .disable-scroll { position: relative; overflow: hidden; height: 100vh; position: fixed; left: 0; top: 0; width: 100%; } .fade { opacity: 0; transition: opacity var(--transition-time); } .fade.animate-open { opacity: 1; transition: opacity var(--transition-time); } .fadeInUp { opacity: 0; transform: translateY(vw(-100)); transition: opacity var(--transition-time), transform var(--transition-time); } .fadeInUp.animate-open { opacity: 1; transform: translateY(0); transition: opacity var(--transition-time), transform var(--transition-time); } .modal__wrapp[data-target="policy"] .modal__content{ left: 1050px; background-color: #000; opacity: .5; } class Modal { constructor(options) { let defaultOptions = { isOpen: () => {}, isClose: () => {}, } this.options = Object.assign(defaultOptions, options); this.modal = document.querySelector('.modal'); this.speed = false; this.animation = false; this.isOpen = false; this.modalContainer = false; this.previousActiveElement = false; this.fixBlocks = document.querySelectorAll('.fix-block'); this.focusElements = [ 'a[href]', 'input', 'button', 'select', 'textarea', '[tabindex]' ]; this.events(); } events() { if (this.modal) { document.addEventListener('click', function(e){ const clickedElement = e.target.closest('[data-path]'); if (clickedElement) { let target = clickedElement.dataset.path; let animation = clickedElement.dataset.animation; if (clickedElement.classList.contains('modal-close')) { this.close(); } let speed = clickedElement.dataset.speed; this.animation = animation ? animation : 'fade'; this.speed = speed ? parseInt(speed) : 300; this.modalContainer = document.querySelector(`[data-target="${target}"]`); this.open(); return; } if (e.target.closest('.modal__close')) { this.close(); return; } }.bind(this)); window.addEventListener('keydown', function(e) { if (e.keyCode == 27) { if (this.isOpen) { this.close(); } } if (e.keyCode == 9 && this.isOpen) { this.focusCatch(e); return; } }.bind(this)); this.modal.addEventListener('click', function(e) { if (!e.target.classList.contains('modal__wrapp') && !e.target.closest('.modal__wrapp') && this.isOpen) { this.close(); } }.bind(this)); } } open() { this.previousActiveElement = document.activeElement; this.modal.style.setProperty('--transition-time', `${this.speed / 1000}s`); this.modal.classList.add('is-open'); this.disableScroll(); this.modalContainer.classList.add('modal-open'); this.modalContainer.classList.add(this.animation); setTimeout(() => { this.options.isOpen(this); this.modalContainer.classList.add('animate-open'); this.isOpen = true; this.focusTrap(); }, this.speed); } close() { if (this.modalContainer) { this.modalContainer.classList.remove('animate-open'); this.modalContainer.classList.remove(this.animation); this.modal.classList.remove('is-open'); this.modalContainer.classList.remove('modal-open'); this.enableScroll(); this.options.isClose(this); this.isOpen = false; this.focusTrap(); } } focusCatch(e) { const focusable = this.modalContainer.querySelectorAll(this.focusElements); const focusArray = Array.prototype.slice.call(focusable); const focusedIndex = focusArray.indexOf(document.activeElement); if (e.shiftKey && focusedIndex === 0) { focusArray[focusArray.length - 1].focus(); e.preventDefault(); } if (!e.shiftKey && focusedIndex === focusArray.length - 1) { focusArray[0].focus(); e.preventDefault(); } } focusTrap() { const focusable = this.modalContainer.querySelectorAll(this.focusElements); if (this.isOpen) { focusable[0].focus(); } else { this.previousActiveElement.focus(); } } disableScroll() { let pagePosition = window.scrollY; this.lockPadding(); document.body.classList.add('disable-scroll'); document.body.dataset.position = pagePosition; document.body.style.top = -pagePosition + 'px'; } enableScroll() { let pagePosition = parseInt(document.body.dataset.position, 10); this.unlockPadding(); document.body.style.top = 'auto'; document.body.classList.remove('disable-scroll'); window.scroll({ top: pagePosition, left: 0 }); document.body.removeAttribute('data-position'); } lockPadding() { let paddingOffset = window.innerWidth - document.body.offsetWidth + 'px'; this.fixBlocks.forEach((el) => { el.style.paddingRight = paddingOffset; }); document.body.style.paddingRight = paddingOffset; } unlockPadding() { this.fixBlocks.forEach((el) => { el.style.paddingRight = '0px'; }); document.body.style.paddingRight = '0px'; } } const modal = new Modal({ isOpen: (modal) => { console.log(modal); console.log('opened'); }, isClose: () => { console.log('closed'); }, });  
    • By ilyamio
      Здравствуйте. Имеется рабочий скрипт конвертера валют. https://ilyamio.github.io/currencyconverter/
      Мне необходимо изменить источник загрузки курсов на ЦБ РФ вот по этой ссылке: https://www.cbr.ru/scripts/XML_daily.asp
      А также мне необходимо установить ограничение на количество обращений к сайту ЦБ РФ - 1 раз в сутки. При частом обращении, могут заблокировать.
      Вот в этом js файле находятся настройки конвертера:
      const from_currencyEl = document.getElementById('from_currency'); const from_ammountEl = document.getElementById('from_ammount'); const to_currencyEl = document.getElementById('to_currency'); const to_ammountEl = document.getElementById('to_ammount'); const rateEl = document.getElementById('rate'); const exchange = document.getElementById('exchange'); from_currencyEl.addEventListener('change', calculate); from_ammountEl.addEventListener('input', calculate); to_currencyEl.addEventListener('change', calculate); to_ammountEl.addEventListener('input', calculate); exchange.addEventListener('click', () => { const temp = from_currencyEl.value; from_currencyEl.value = to_currencyEl.value; to_currencyEl.value = temp; calculate(); }); function calculate() { const from_currency = from_currencyEl.value; const to_currency = to_currencyEl.value; fetch(`https://api.exchangerate-api.com/v4/latest/${from_currency}`) .then(res => res.json()) .then(res => { const rate = res.rates[to_currency]; rateEl.innerText = `1 ${from_currency} = ${rate} ${to_currency}` to_ammountEl.value = (from_ammountEl.value * rate).toFixed(2); }) } calculate(); Как мне изменить настройки в этом файле чтобы курсы брались с https://www.cbr.ru/scripts/XML_daily.asp и включить ограничение на количество обращений по ссылке cbr.ru - 1 раз в сутки?
      Заранее спасибо всем, кто хотел помочь с решением этой задачи.
    • By vasyl_runner
      $(function () { var mixer = mixitup('.directions__list'); $('.directions__filter-btn').on('click', function () { $('.directions__filter-btn').removeClass('directions__filter-btn--active') $(this).addClass('directions__filter-btn--active') }) })
    • By Yurich
      Всем привет, у меня такой вот вопрос, делаю сайт через react и при изменении расширения что-то идёт не так и какой-то бред получается, подскажите как решить данную проблему. Я вообще не понимаю из-за чего это происходит, по этому не могу нормально объяснить 😅.

    • By KatiaBeing
      Подскажите пожалуйста, как правильно сделать кастомный список стран используя API.
      Вот fetch код:
       
      const countryList = document.querySelector('.form-list.country'); fetch('https://restcountries.com/v3.1/all').then(res => { return res.json(); }).then(data => { let output = ''; data.forEach(country => { output += `<li class="form-item" data-value="${country.name.common}">${country.name.common}</li>`; countryList.innerHTML = output; }); }).catch(err => { console.log(err); }); полный код html, css, js Во втором списке "Country" список формируется, но название страны не поставляется в форму, а атрибут "data-value="" " в инпут ниже. В первом списке "Guests Amount" все ок, т.к. данные прописаны в html. Нужен такой же, но со странами.
      Сразу скажу, с тегом select все работает, но мне нужна стилизованная выпадашка. Заранее спасибо.
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy