Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 18.03.2014, 16:57
Интересующийся
Отправить личное сообщение для sl1m Посмотреть профиль Найти все сообщения от sl1m
 
Регистрация: 28.10.2013
Сообщений: 17

Не назначается eventlistener
что может быть не так?
http://jsfiddle.net/8qbaL/
Ответить с цитированием
  #2 (permalink)  
Старый 18.03.2014, 17:38
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,103

sl1m,
со строки 5 закончились переменные - запятые поменять на точку с запятой строки 5 - 11.
строка 60 нет никакого value у span и значение функции никогда неизменится параметр input
Ответить с цитированием
  #3 (permalink)  
Старый 18.03.2014, 18:08
Интересующийся
Отправить личное сообщение для sl1m Посмотреть профиль Найти все сообщения от sl1m
 
Регистрация: 28.10.2013
Сообщений: 17

так там не просто input, а input.value, eventlistener появился, но не работает функция.

З.ы.: это тестовые задания на повышения, не могли бы помочь, сам то я backend developer.
Ответить с цитированием
  #4 (permalink)  
Старый 18.03.2014, 18:10
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,103

Сообщение от sl1m
так там не просто input, а input.value
это то и недаёт сменится параметру!!! как при загрузке получили значение больше оно у вас не сменится

Последний раз редактировалось рони, 18.03.2014 в 18:13.
Ответить с цитированием
  #5 (permalink)  
Старый 18.03.2014, 18:11
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,103

sl1m,
<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="content-type" content="text/html; charset=UTF-8">
  <title> - jsFiddle demo</title>

  <script type='text/javascript' src='/js/lib/dummy.js'></script>



  <link rel="stylesheet" type="text/css" href="/css/result-light.css">

  <style type='text/css'>

  </style>



<script type='text/javascript'>//<![CDATA[

window.onload = function(){
var input = document.getElementById("int"),
    button = document.getElementById("success"),
    result = document.getElementById("result"),
    assocArr = [];
    assocArr[0] = new Array("", "один", "два", "три", "четыри", "пять", "шесть", "семь", "восемь", "девять");
    assocArr["d"] = new Array("десять", "одинадцать", "двенадцать", "тринадцать", "четырнадцать", "пятнадцать", "шеснадцать", "семнадцать", "восемнадцать", "девятнадцать");
    assocArr[1] = new Array("", "", "двадцать", "тридцать", "сорок", "пятьдесят", "шестьдесят", "семьдесят", "восемьдесят", "девяносто");
    assocArr[2] = new Array("", "сто", "двести", "триста", "четыреста", "пятьсот", "шестьсот", "семьсот", "восемьсот", "девятьсот");
    assocArr["s"] = new Array("", "одна", "две");
    assocArr[3] = new Array("тысяч", "тысяча", "тысячи", "тысячи", "тысячи", "тысяч", "тысяч", "тысяч", "тысяч", "тысяч", "");

function numToWord(number) {
    var resp = "",
        numArr = [],
        flag = true;

    if (isNaN(number) || number < 1 || number > 9999) {
        return "Invalid input!";
    }

    for (; number != 0; number = Math.floor(number / 10)) {
        numArr.push(number % 10);
    }

    for (var i = numArr.length - 1; i >= 0 ; i--) {
        if (flag) {
            if (numArr[i] == 1 && i == 1 || numArr[i] == 1 && i == 4) {
                flag = false;
            } else {
                resp += digitToWord(i, numArr[i], 0);
            }
        } else {
            resp += digitToWord("d", numArr[i], i);
            flag = true;
        }
    }
    return resp.trim();
}

function digitToWord(digit, offset, char) {
    var resp = "";
    switch (digit) {
        case 3:
            resp += (offset == 1 || offset == 2 ? assocArr["s"][offset] : assocArr[0][offset]) + " ";
            break;
        case 4:
            digit = 1;
            break;
        case "d":
            resp += assocArr[digit][offset] + " ";
            digit = char;
            offset = 0;
            break;
    }
    return resp + assocArr[digit][offset] + " ";
}

function getResult(){
   result.innerHTML = numToWord(input.value);
}

button.addEventListener("click", getResult, false);
}

</script>


</head>
<body>
  <label for="int"> Insert number </label>
    <input type="text" name="int" id="int"/>
    <br/>
    <button type="submit" id="success"> Go </button>
    <br/>
    <span id="result"></span>

</body>


</html>
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
не назначается bind после unbind constantant jQuery 7 15.09.2009 13:59
Изменить EventListener halgerd Events/DOM/Window 2 30.04.2008 21:29