Ответы пользователя по тегу JavaScript
  • Изменение стиля при помощи javascript

    apangin
    @apangin
    1 вариант. Хранить id предыдущего нажатого в (глобальной) переменной.
      var old_id;
      function kodimg(id) {
        if (old_id) document.getElementById(old_id).className = 'b-img';
        document.getElementById(id).className = 'v-img';
        old_id = id;
      }

    2 вариант. В функции kodimg сначала у всех div сменить класс на b-img, затем у нужного поставить v-img.
      function kodimg(id) {
        for (var i = 1; i <= 5; i++) document.getElementById(i).className = 'b-img';
        document.getElementById(id).className = 'v-img';
      }

    И, независимо от выбранного варианта, почитать для начала книжки и поизучать материал в интернете.
    Ответ написан
    1 комментарий
  • Что означает контрукция типа “(function(d){ ... })(document)”

    apangin
    @apangin
    1. Чтобы ограничить область видимости, т.е. избежать глобальных переменных.
    2. Чтобы сократить запись обращения к объекту.
    3. Как частный случай 1го и 2го, чтоб не допустить конфликта имен. Например, при использовании jQuery часто пишут
        (function($) {
            ...
        })(jQuery);

    Благодаря этому в скрипте можно использовать сокращенную запись типа $(xxx), даже если идентификатор $ определен где-то еще, например, в MooTools.

    P.S. И это, кстати, не замыкание.
    Ответ написан
    5 комментариев
  • JavaScript: объясните return в конструкторе

    apangin
    @apangin
    Для простоты понимания примеры можно сократить до следующих.
    Первый: function Test() { this.qqq = a; }
    Второй: function Test() { return {qqq: 'a'}; }

    Теперь обратимся к спецификации ECMA-262, пункт 13.2.2. [[Construct]]

    When the [[Construct]] property for a Function object F is called, the following steps are taken:
    1. Create a new native ECMAscript object.
    2. Set the [[Class]] property of Result(1) to «Object».
    3. Get the value of the prototype property of the F.
    4. If Result(3) is an object, set the [[Prototype]] property of Result(1) to Result(3).
    5. If Result(3) is not an object, set the [[Prototype]] property of Result(1) to the original Object prototype object as described in 15.2.3.1.
    6. Invoke the [[Call]] property of F, providing Result(1) as the this value and providing the argument list passed into [[Construct]] as the argument values.
    7. If Type(Result(6)) is Object then return Result(6).
    8. Return Result(1).

    Разгадка кроется в двух последних строках: если функция возвращает объект, то результатом работы конструктора считается этот объект, если же функция возвращает что-либо другое (либо ничего не возвращает), результатом работы конструктора считается новый объект, созданный на шаге 1.
    Ответ написан
    1 комментарий