Вложений: 2
Вот собственно результат. Напомню что сайт на платформе Ucoz
|
Загрузчик не о чем
http://uchudesami.ru/rezult.png
http://uchudesami.ru/rezult2.png Вот результаты труда. Как мне сделать взаимосвязь функции и <select>??? |
JimHudson,
<select name="region" onchange="regionChange(this)"> <option value="0">Выберите регион доставки</option> <option value="300">Красноярский край</option> <option value="200">Ленинградская область</option> <option value="200">Московская область</option> <option value="300">Омская область</option> <option value="650">Другой</option> </select> <script> function regionChange(region) { alert(region.value); } </script> |
спасибо огромное, но проблема еще не решена.последнии три строчки моей функции
if($('input[name="custom_delivery_tax"]').length == 0 $('#checkout-form').append('<input type="hidden" name="custom_delivery_tax" value="0">'); } $('input[name="custom_delivery_tax"]').val(cost); добавляют числовой результат в общую стоимость заказа. как мне их применить? нужно решение без alert. и как функцию js подключить из внешнего файла? |
ТС, ты зачем мозг насилуешь? Тебе всего-то надо заменить несколько переменных по одному всего лишь признаку. Сделай таблицу цен по рыгионам и подставляй нужный объект, ты мужик или не мужык?
var costs={}, Cost; /* выбранный регион */ costs.msk={ name:Мозгва, 0:970, 1:100, 12:300, 31:0 }; costs.nsk={ name:Новосибирск 0:670, 1:200, 12:500, 31:0 }; /* продолжай копипастить и менять цены по дням для рыгиона */ costs.spb={ name:Питербурх 0:170, 1:600, 12:600, 31:1 }; Cost=costs.msk; /* дефаульт сити */ Теперь делаешь список var html=[]; for(var item in costs) html.push('<option value="'+key+'"'+((costs[key]===Cost)?' selected':'')+'>'+costs[key].name+'</option>'; some_elem.innerHTML='<select>'+html.join('')+'</select>'; some_elem.addEventListener('change',calc); Теперь калькируешь var calc=function(e){ /* если есть такой регион, то взять, иначе в мозгву, или какой-то дефольт */ var region = (costs.hasOwnProperty(this.value))?costs[this.value]:costs.msk /* в var today; номер дня, если не твой день, то дефолт */ Cost = region.hasOwnProperty(today)?cost[today]:cost[0]; }; Всенах. |
ЗЫ. Таблица ненормальна, но тут уловки: номер дня - это число, значит топоним можно заеписать через текстовый ключ, прямо в отношение и вторая - нулевого дня не бывает, поэтому дефолт в пишется в 0, кроме того к 0 эволюционируют все пустые значения.
|
Заделал рабочий прототип
<!DOCTYPE html> <html lang="ru" dir="ltr"> <head> <meta charset="utf-8"> </head> <body> <div><input type="text" id="day" value="1"/></div> <br/> <div id="list"></div> <br/> <button id="btn">Посчитать</button> <br/> <div id="result"></div> <script> var costs={}, today, Cost; costs.msk={ name:'Мозгва', '0':970, '1':100, '12':300, '31':0 }; costs.nsk={ name:'Новосибирск', '0':670, '1':200, '12':500, '31':0 }; costs.spb={ name:'Питербурх', '0':170, '1':600, '12':600, '31':1 }; var html=[]; for(var key in costs) html.push('<option value="'+key+'"'+(costs[key]===Cost?' selected':'')+'>'+costs[key].name+'</option>'); document.getElementById('list').innerHTML='<select>'+html.join('')+'</select>'; var calc=function(e){ /* если есть такой регион, то взять, иначе в мозгву, или какой-то дефольт */ var region = (costs.hasOwnProperty(this.value))?costs[this.value]:costs.msk today=document.getElementById('day').value; Cost = region.hasOwnProperty(today)?region[today]:region[0]; }; var show=function(){ document.getElementById('result').innerHTML='<p>Сегодня цена доставки: '+Cost + ' руб.'; }; document.getElementById('btn').addEventListener('click',show); list.querySelector('select').addEventListener('change',calc); today=document.getElementById('day').value; Cost=costs.msk[today]; /* дефаульт сити */ </script> </body> </html> |
warren buffet,
спасибо, опять не то. меня по ходу никто не понял. ты есть вконтакте? скинь в личку ссылку |
Вот исходная функция.
var myCalculator = function(day){ // стоимость доставки var cost = 0; switch(day) { // каждое первое число месяца стоимость равна 100у.е. case 1: cost = 100; break // каждое двенадцатое число месяца стоимость равна 200у.е. case 12: cost = 200; break // каждое тридцать первое число месяца доставка бесплатна (таких дней всего 7 в году) case 31: cost = 0; break // по остальным дням мы не так щедры, доставка 500у.е. default: cost = 500; } // если поле custom_delivery_tax не существует if($('input[name="custom_delivery_tax"]').length == 0){ // добавить его $('#checkout-form').append('<input type="hidden" name="custom_delivery_tax" value="0">'); } // запись стоимости доставки в поле custom_delivery_tax $('input[name="custom_delivery_tax"]').val(cost); } она считает стоимость доставки в зависимости от дня месяца. мне необходимо ее переделать, чтобы она считала стоимость в зависимости от региона. например: в функции прописать регион 1, регион 2, регион 3= 200руб регион 4, регион 5 =300 руб регион 6 = 400 руб и т.д. за счет <select> создаем динамический список регионов. покупатель выбирает свой регион из списка, а скрипт сравнивает соответствие регион-стоимость и выводит покупателю стоимость доставки, плюс прибавляет ее к общей стоимости. Роль прибавления стоимости выполняют три последние строки исходной функции. комментарии написанные в исходной функции динамим, они для расчета по дням, нам нужно по регионам. вот. попытался подробно изложить. сейчас поищу пример уже готовой задумки. |
Rise,
с юкозом имел дело? |
Часовой пояс GMT +3, время: 23:16. |