Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
:)
 Аватар для PlumBoom
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428

Объект jQuery через свойство объекта-литерала

11.11.2013, 15:00. Показов 869. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день ) Не могу понять, почему через свойство не работает:
JavaScript
1
2
3
4
5
6
7
8
var Menu = {
    el: $('#wrapper') //, дальнейшая реализация объекта Menu
};
 
$(document).ready(function () {
   
    Menu.el.css({'background-color':'#000'});
});
Через метод работает:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
var Menu = {
    el: function () {
        return $('#wrapper');    
    }
};
 
 
$(document).ready(function () {
   
    Menu.el().css({'background-color':'#000'});
});
Объясните, что за парадокс
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.11.2013, 15:00
Ответы с готовыми решениями:

Ссылка через свойство объекта на объект
Собственно сабж - возможно ли это ? var obj:Object = new Object(); obj = 1; Можно ли через свойство "a" получить ссылку на...

Передать свойство объекта в свойство объекта в объекте что в массиве
var array = ; function func(a, b, c) { array = {}; array.a = {}; // вместо "a" - аргумент array.a.b = text3; // и здесь. } ...

Применить свойство hover через другой объект
Здравствуйте Структура такова: <div class="bl1"> <div class="bl11" </div> <div...

8
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
11.11.2013, 15:26
Цитата Сообщение от PlumBoom Посмотреть сообщение
Объясните, что за парадокс
Свежую версию jQuery используйте(у меня ваш код работает)

Если не получается, то попробуйте поместить var Menu в коллбек ready
0
:)
 Аватар для PlumBoom
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
11.11.2013, 15:41  [ТС]
Это и есть последняя версия jQuery.
Цитата Сообщение от Padimanskas Посмотреть сообщение
Если не получается, то попробуйте поместить var Menu в коллбек ready
Тоже не работает. Скорее всего, вы проверили 2 код, а не первый.
0
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
11.11.2013, 15:53
Цитата Сообщение от PlumBoom Посмотреть сообщение
Скорее всего, вы проверили 2 код, а не первый.
Нет, первый проверял. Может быть у вас несколько #wrapper-ов на странице?
0
:)
 Аватар для PlumBoom
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
11.11.2013, 15:57  [ТС]
Цитата Сообщение от Padimanskas Посмотреть сообщение
Нет, первый проверял. Может быть у вас несколько #wrapper-ов на странице?
Какая версия jQuery и какой браузер?
Я проверял в хроме последней версии (30) и jQuery 1.10.2 и 2.0.3

Не может быть несколько врапперов, т.к. используется идентификатор
0
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
11.11.2013, 16:04
Цитата Сообщение от PlumBoom Посмотреть сообщение
Не может быть несколько врапперов, т.к. используется идентификатор
Да, все равно бы работало, это на вскидку предположил...

У меня FireFox 25.0 и Chrome 30.0, jQuery - 1.10.2. Вот таким образом я проверяю:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<!DOCTYPE html>
<html>
 
<head>
    <meta charset="utf-8" />
    <title>Example</title>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
</head>
 
<body>
 
<div id="wrapper" style="width:100px; height:100px;"></div>
 
    <script>
    
        var Menu = {
            el : $('#wrapper')
        };
 
        $(document).ready(function () {
            Menu.el.css({
                'background-color' : '#000'
            });
        });
 
    </script>
</body>
 
</html>
1
:)
 Аватар для PlumBoom
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
11.11.2013, 16:25  [ТС]
Огромное спасибо) Дело в том, что у меня скрипт был в секции head
Получается, что свойство el в объекте Menu инициализировался до загрузки документа, а $('#wrapper') естественно вернул, что объект не найден - ведь его на данном этапе еще не существует Метод вызывался уже после загрузки документа, поэтому всё работало Вот теперь я выяснил причину) Огромное спасибо еще раз)

Свойства (не методы) инициализируются сразу же (методы в принципе тоже инициализируются сразу же... только идет присваивание ссылки на объект вызова)...
просто я не внимателен и не увидел элементарную вещь
0
Superposition
 Аватар для Padimanskas
950 / 615 / 256
Регистрация: 27.10.2013
Сообщений: 2,083
11.11.2013, 16:51
Если бы я только знал каким образом у вас выполняется скрипт
Переменные определяются на стадии интерпретации самыми последними и принимают значение undefined.
Хорошо, монета в копилку опыта.
0
:)
 Аватар для PlumBoom
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
12.11.2013, 08:54  [ТС]
Значение undefined принимают переменные в том случае, если ничего не присваивается или не присваивалось никакое значение с момента определения этой переменной
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.11.2013, 08:54
Помогаю со студенческими работами здесь

Задать свойство объекта через переменную
Добрый день. Есть такой код: $('.sliderBlock .textInput').on(&quot;blur&quot;, function() { var valueType =...

Активация объекта через объект
Добрый вечер форумчане! Необходима ваша помощь с скриптом. Задача такая: Необходимо через объект(условно кнопка) по нажатию кнопки на...

Прохождение твердого объекта через твердый объект
Здравствуйте. У меня есть два объекта. Первый объект bomber, второй block. На обоих объектах висит BoxCollider2d. На объект bomber...

Добавить в уже существующий объект свойство и положить в него объект
У меня имеется такая вложенность в редьюсере initialState = { prop1: { props2: { prop3: {id:...

Объект класса, созданный через конструктор копирования, зависим от объекта, с которого брали копию
Объект класса, созданный через конструктор копирования, зависим от объекта, с которого брали копию. При изменении параметров первого...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru