Объекты Javascript в примерах
Объекты (они же - ассоциативные массивы, хэши) и работа с ними в Javascript - реализованы не так, как в большинстве языков. С этим связано много ошибок и непоняток.
В этой статье описаны базовые свойства объектов javascript, создание и изменение, перечисление свойств и т.п.
Объект в javascript представляет собой обычный ассоциативный массив или, иначе говоря, "хэш". Он хранит любые соответствия "ключ => значение" и имеет несколько стандартных методов.
Метод объекта в javascript - это просто функция, которая добавлена в ассоциативный массив. Далее - подробнее.
Следующие два варианта создания объекта эквивалентны:
// эквивалентные записи
var o = new Object()
var o = {}
Есть два синтаксиса добавления свойств в объект. Первый - точка, второй - квадратные скобки:
// эквивалентные записи
o.test = 5
o["test"] = 5
Квадратные скобки используются в основном, когда название свойства находится в переменной:
var name = 'test'
o[name] = 5
Здесь имя свойства "test" является ключом в ассоциативном массиве, по которому лежит значение 5.
Доступ к свойству осуществляется точно так же:
alert(o.test)
alert(o['test'])
Если у объекта нет такого свойства, то результат будет 'undefined'
var o = {}
alert(o.nosuchkey) // => undefined
Никакой ошибки при обращении по несуществующему свойству не будет, просто вернется специальное значение undefined.
Проверка глобальной переменной
В javascript нельзя проверить существование глобальной переменной простым if:
if (x) { ... }
Если x не определен, то конструкция if (x) вызовет ошибку javascript.
Распространенное решение - использовать typeof:
if (typeof x != 'undefined') { ... } // или typeof(x)
Однако зная, что глобальная переменная в javascript - всего лишь свойство объекта window - мы можем записать проще:
if (window.x) { ... } // правильный аналог if(x)
// или
if (window.x !== undefined) // аналог typeof x ..
Все свойства объектов - public, т.е при определении свойства никак нельзя ограничить доступ к свойству. В javascript есть специальные выверты для создания private свойств, связанные с замыканиями. Они рассмотрены вместе с наследованием объектов.
Удаляет свойство оператор delete:
o.test = 5
delete o.test
o['bla'] = true
Свойства можно указывать непосредственно при создании объекта, через список в фигурных скобках вида {..., ключ : значение, ...}:
var o = {
test: 5,
bla: true
}
Получившийся объект можно изобразить так:

Как и в других языках, у объектов javascript есть методы.
Например, создадим объект rabbit с методом run
var rabbit = {}
rabbit.run = function(n) {
alert("Пробежал "+n+" метров!")
}
Добавление метода в объект - просто присвоение функции function(n) { ... } свойству rabbit.run.
Теперь можно запускать
var rabbit = {}
rabbit.run = function(n) {
alert("Пробежал "+n+" метров!")
}
rabbit.run(5) // Пробежал 5 метров
rabbit.run(7) // Пробежал 7 метров
Здесь не идет речь о классах, создании экземпляров и тому подобном. Просто - в любой объект в любое время можно добавить новый метод или удалить существующий.
Javascript - очень динамический язык, не правда ли?
Обычно хочется, чтобы метод не просто вызывался из объекта, но имел доступ к самому объекту, мог менять находящиеся в нем данные.
Для этого используется ключевое слово this:
for(var key in obj) {
… obj[key] …
}
В отличие от многих языков, this никак не привязано к объекту, а обозначает просто объект, вызвавший функцию.
Например,
function this1() {
var vasya = { name:'Вася' }
var petya = { name:'Петя' }
sayName = function() {
alert("Я - "+ (this.name ? this.name : 'безымянный') )
}
vasya.sayName = sayName
// один и тот же метод в двух объектах
petya.sayName = vasya.sayName
// тут - this будет petya
petya.sayName() // Я - Петя
// тут - this будет vasya
vasya.sayName() // Я - Вася
// а тут - вызывается метод глобального объекта window, у которого нет имени
sayName() // Я - безымянный
}
Запустить this1()
Более подробно о том, как работает this можно почитать в этой статье.
Для перебора всех свойств объекта используется специальный вид конструкции for, for..in:
for(var key in object) {
// key - название свойства
// object[key] - значение свойства
...
}
Например,
var o = {a:5, b:true}
for (var key in o) {
alert(key+':'+o[key])
}
Запустить
Это уже выходит за рамки текущей статьи, но вообще - существует еще одна форма перебора свойств, которая более надежна, особенно если используется библиотека типа prototype.
for(prop in object) {
if (!object.hasOwnProperty(prop)) continue
//...
}
Эта форма отфильтровывает свойства, которые принадлежат не самому объекту, а его прототипу. Поэтому она работает, даже если в прототип Object добавлены новые свойства.
Более элегантный вариант записи:
for(prop in object) if (object.hasOwnProperty(prop)) {
//...
}
|
Автор: klubben (не зарегистрирован), дата: 7 июня, 2008 - 12:10
#permalinkА почему ничего не сказано про прототипы (aka классы)?
function a () { // объявляем класс
}
// добавляем метод для прототипа
a.prototype.b = function () {
alert ('test');
}
// создаем объект
var a = new a();
Автор: anima (не зарегистрирован), дата: 19 июня, 2008 - 13:51
#permalinkХорошие статьи. Коротко, самое важное, без утаревших приемов, и всякой лабуды. Но я, собственно, по поводу Доступ к объекту из метода.
Раньше, было не нужно, а сейчас потребовалось, из повешанного на объект метода, получить ссылку не на объект его вызвавший, а на объект, на котором висит сам метод. Вроде вот он рядом :-), а как достать? Понимаю, что можно использовать прототип, но это нарушит всю задуманную задачу. Перекопал сегодня пол Интернета, но как то не смог ни чего найти. Такое чувство, что есть какая то простейшая возможность, но я её упустил.
Сам метод генерится динамически, и я, в принципе, могу жестко забить ссылку на объект, но это вроде не этично. :-)
Автор: Гость (не зарегистрирован), дата: 30 июня, 2008 - 11:21
#permalinkкак можно исползоват функции php в javascript
Автор: Bratok (не зарегистрирован), дата: 15 августа, 2008 - 18:08
#permalinkА можно ли изменит порядок свойств объекта? Можно ли с объектом работать как с массивом т.е. использовать теже методы предусмотренные для объект Array?
Автор: Bratok (не зарегистрирован), дата: 17 августа, 2008 - 08:01
#permalinkНу, ладно с предыдущим вопросом я разобрался. Ввод: нельзя. Другой ворос, можноли получить как-нибудь ссылку на свойство объекта, именно ссылку.
Автор: Гость (не зарегистрирован), дата: 18 августа, 2008 - 18:41
#permalinkинтересная статья. Много полезного узнал. Но вот интересно как можно вызывать метод объекта через setTimeout? Странно, вызов происходит, только метод не может получить доступ к свойствам объекта.
Автор: Алексей_Р (не зарегистрирован), дата: 2 марта, 2009 - 01:20
#permalinkПочему, когда я пытаюсь объявить объект Google maps в глобале,
ничего не происходит?
var map = new google.maps.Map2(document.getElementById("map")); function mapsLoaded() { map.setCenter(new google.maps.LatLng(37.4419, -122.1419), 13); //Не работает }Автор: kefi, дата: 14 марта, 2009 - 02:57
#permalinkЕсли Array является объектом (встроенным) со свойствами constructor,length,prototype,concat,join etc..., то почему я не могу перечислить его свойства путем :
for (var key in Array) { alert(key+':'+ Array.prototype.hasOwnProperty(key)+'&') }или
for (var key in Array) { alert(key+':'+ Array.hasOwnProperty(key)+'&') }?
Автор: kefi, дата: 15 марта, 2009 - 19:11
#permalink[quote]Атрибут DontEnum[/quote] Да про него уже скзали выше. Интересуют ответы на "наведенные вопросы" см выше по поводу аттрибутов ?!
А ответ на этот вопрос тоже должен быть не такой, как я понял , а такой :
alert(Array.hasOwnProperty("join")) // false, потому , что Array здесь ошибочно употреблен в качестве объекта типа Array, в то время , как в такой нотации он является объектом типа Function, т.к. возвращает ссылку на конструктор Array.
alert(Array.prototype.hasOwnProperty("join") ) // trueпотому , что Array.prototype здесь возвращает ссылку на прототип объектов,имеющих тип Array, который уже обладает этим собственным свойством.
Кстати, для
var a = new Array(); alert(a.hasOwnProperty("join")) // =falseпотому, что объект a действительно не имеет собственного Own свойства "join" , оно для этого объекта берется из его прототипа (на прототип объекта a указывает свойство prototype его конструктора Array.prototype),
Автор: Леонид Евстигнеев, дата: 31 мая, 2009 - 18:43
И в чём принципиальная разница между a и b в следующем коде.
var a = new Object(); function myFunc(){}; var b = new MyFunc();Я так понимаю ссылкой prototype (или [[prototype]]) и как следствие набором свойств и методов. Или ещё чем...? И можно ли сказать, что b создается как и а, но после создания b вызывается ещё и MyFunc() (с this указывающем на b)
Автор: sarlv (не зарегистрирован), дата: 17 января, 2010 - 02:38
#permalinkПодскажите пожалуйста!!!
Есть такой когд (смотреть ниже), где нужно передать id в функцию clickFunction().
В результате получаю null. Пробовал ввести id напрямую, т. е. "list", браузер не выводит вообще ничего.
<html> <head> <script type="text/javascript"> function clickFunction(elemId){ alert(elemId); } var getId = document.getElementById("list"); var altF = new clickFunction(getId); </script> <title></title> </head> <body> <ul id="list"> <li>Item 1</li> <li>Item 2</li> <li>Item 3</li> </ul> </body> </html>P.S.: заранее приношу ивинения, если пишу не туда.
Я "чайник"
Автор: sarlv (не зарегистрирован), дата: 17 января, 2010 - 03:02
#permalinkПрошу прощения, читать так:
alert(elemId.nodeName);
Автор: PieceOfMeat (не зарегистрирован), дата: 29 марта, 2010 - 16:12
#permalinkПрошу прощения если не заметил, но по-моему у вас нигде не написано, что объекты в Javascript передаются и копируются по ссылке.
И было бы интересно увидеть функцию clone, которая делала бы копирование объектов по значению.
Автор: Гость (не зарегистрирован), дата: 28 мая, 2010 - 15:08
#permalinkНе перепутан ли в статье этот пример:
Для этого используется ключевое слово this:
for(var key in obj) { … obj[key] … }И хотел спросить. Так я обращаюсь к свойствам объекта из метода:
var obj = { property : 0, a : 0, b : 0, c : 0 } obj.method = function(n) { this.property = n * this.a + ( this.b + n ) / this.c; }Возможно ли обращение без this?
Автор: Александр второй (не зарегистрирован), дата: 29 мая, 2010 - 17:53
#permalinkНе нашел на сайте, где можно посмотреть как можно сделать так чтобы при наведении мыши на страницу происходило какое-то действие. Подскажите.
Автор: гость (не зарегистрирован), дата: 21 июля, 2010 - 15:08
#permalinkИзвиняюсь за глупый вопрос)
var o = {} //создали объект o['test'] = 5 //добавили свойство alert(o['test']) //выводит 5Подскажите почему если вместо alert(o['test']) прописать alert(o.test) то будет выведено undefined. Ведь сказано что o - это объект, а test - его свойсто. Тоесть у него же есть свойство.
Автор: mch (не зарегистрирован), дата: 23 августа, 2010 - 10:28
#permalinkЕсли я создаю объект с несколькими свойствами и присваиваю в качестве значений, например, Image при создании объекта в память будет загружены изображения для каждого указанного свойства или свойствам будут присвоены только ссылки на Imagе. Т.е. интересует вопрос выделения памяти под объект в этом случае.
var img = new Image ();
img.src = "a.jpg";
var o = { b1: img, b2: img, b3: img }
Автор: Гость (не зарегистрирован), дата: 24 августа, 2010 - 16:59
#permalinkв опере 9.6 баг нашел.
в мазиле и в ие можно так делать:
var a=new Array()
a['top']='dfgd.kfg'
a['bottom']='dfgkldfg'
a['dfgqwdf']='dfl.kgdfg'
а потом обращатся двумя способами:
var c=a.top // c='dfgd.kfg'
var c=a['top'] // c='dfgd.kfg'
так вот в опере работает только второй способ.
Автор: Гость, дата: 17 сентября, 2010 - 14:48
#permalinkНе поверите, беру первый ваш пример, вставляю в текст своей страницы и ничего не происходит. С этой страницы, кстати, работает.
var rabbit = {}
rabbit.run = function(n) {
alert("Пробежал "+n+" метров!")
}
rabbit.run(5) // Пробежал 5 метров
rabbit.run(7) // Пробежал 7 метров
Автор: CraZZZy-GameRRR (не зарегистрирован), дата: 9 октября, 2010 - 18:53
#permalinkПодскажите пожалуйста, как сделать переменную-указатель на свойство объекта, т.е. изменяю я значение переменной и изменяется свойство нужного мне объекта.
Автор: Гость (не зарегистрирован), дата: 10 октября, 2010 - 10:31
#permalinkИзвините если глупость сморозил, я начинающий js-программист. Есть код:
function myobj() { // some code } myobj.prototype.f = function() { alert(a); } /* 1 */ var obj = new myObj(); obj.a = 10; obj.f(); /* 2 */ var obj = { a: 10 } obj.f(); // !!!Как мне сделать чтобы второй вариант работал как первый (извините, иначе сформулировать не смог :-) ) Тоесть чтобы во втором случае обьект создался как в первом, что ли
Автор: monolithed, дата: 11 декабря, 2010 - 20:43
#permalinkОбъекты (они же - ассоциативные массивы, хэши) и работа с ними в Javascript - реализованы не так, как в большинстве языков. С этим связано много ошибок и непоняток.Илья, это вводит в заблуждение некоторых пользователей, начиная с того что одни утверждают, что в JS объектов, заканчивая тем что есть только ассоциативные массивы, хэшы.
Предлагаю подкорректировать и сослаться/процитировать стандарт: http://javascript.ru/ecma/part4#a-4.2.1
Автор: Andrey1988 (не зарегистрирован), дата: 18 декабря, 2010 - 17:36
#permalinkЗдравствуйте. У меня стоит задача получить доступ к переменным на странице, а точнее к переменным класса. Для этого я перебираю циклом for...in все свойства объекта window:
В опере и хроме скрипт отрабатывает правильно, находит переменные a и b. Чего не скажешь про IE, который просто выдает ошибку в строке 9: "предполагается наличие объекта". Получается, что IE попросту не видит эти переменные в цикле. При этом мне нужно, чтобы скрипт работал именно под IE.
В чем может быть проблема?
Автор: Pruvet (не зарегистрирован), дата: 28 декабря, 2010 - 19:59
#permalinkДоступ к свойствам.
есть вот такой код:
profiler=function(_timeout) { var timeout=_timeout var delay = 0 var timer = new Date() this.min = timeout this.max = timeout var _profiler = function() { var _timer = new Date() delay=_timer-timer min = Math.min(min,delay) //min - undefined max = Math.max(max,delay) //max - undefined this.min = Math.min(min,delay) //this = window this.max = Math.max(max,delay) //this = window timer=_timer setTimeout(_profiler,timeout) } thisl.getDelay=function(){ return delay } try{ clearTimeot(this.timerID) } catch(e){ this.timerID=setTimeout(_profiler,timeout) } } prof = new profiler(100)При работе метода _profiler класса profiler по таймауту не могу получить доступ к свойствам min и max.
Доступ к delay получил через замыкание, при этом потерял доступ к delay из-вне класса _profiler. Для получения доступа на чтение добавил функцию getDelay.
Вопрос: как получить доступ к min и max из _profiler и из-вне класса profiler не создавая дополнительных методов для доступа к min и max?
Автор: star (не зарегистрирован), дата: 11 января, 2011 - 20:38
#permalinkВот есть такой код:
var A = {'5':'1', '1':'2'}; for(var i in A) alert(i + ':'+ A[i]);Все бы ничего, одно НО! гугл хром выводит алерты, отсортировав его по ключам (сначала 1:2, потом 5:1), хотя в мозилле и Ие так, как записаны....
как все таки в хроме обойти объект так, как он задан?
хотя такой код
var A = {'_5':'1', '_1':'2'};выводит то что нужно, но насильно пихать, а потом срезать "лишние" символы не очень то и хочется
Автор: MODist, дата: 13 января, 2011 - 11:49
#permalinkЗдравствуйте. Объясните разницу.
function people() {} people.prototype.say= function() { return "hello"; } console.log(people.say()); // TypeError: people.say is not a function people.say = function() { return "hello"; }; console.log(people.say()); // helloПочему в первом случае будет ошибка а во втором - нет? Какая разница если мы добавляем методы через prototype и через точку?
Автор: frankbakulov (не зарегистрирован), дата: 15 января, 2011 - 18:12
#permalinkПрошу прощения если не заметил, но по-моему у вас нигде не написано, что объекты в Javascript передаются и копируются по ссылке.
Вот это очень правильное замечание!
Только что на это наткнулся и испытал неприятное удивление - был уверен, что в js, как в нормальных языках, оператор "=" присваивает правую часть левой И БОЛЬШЕ НИЧЕГО.
Считаю, статья должна начинаться с этого.
Автор: ReptatmogeVog (не зарегистрирован), дата: 3 февраля, 2011 - 16:23
#permalinkда, что-то на подобии этого
Автор: Zeran (не зарегистрирован), дата: 16 марта, 2011 - 17:58
#permalinkВсе никак не разберусь, как реализовано в jQuery такое:
$("myDiv").html()Как сделать свои функцию в функции?
Автор: Гость (не зарегистрирован), дата: 29 марта, 2011 - 11:58
#permalinkХочу "переименовать" id объекта через
document.getElementById( "sId").id = "sNewId";
Все работает, за исключением случая когда объект является активным объектом документа (т.е. имеет фокус). Другими словами переименование НЕ проходит с объектами, которые имеют во время выполнения скрипта фокус.
Как решить?
Автор: mrGreed, дата: 1 апреля, 2011 - 11:06
#permalinkДабавлю баянчик про хорошую статью .. Действительно - огромное спасибо автору(ам) за проект.
К делу. у Меня есть объект типа
{"<уникальный числовой код":["<значение1>","<значение2>",..],-||-,..}проблема в том, что стандартным выводам
создаются DOM-узлы упорядоченные по числовому ключу соотвественно, а необходимо бы - по конкретному значению из списка.
Стоит сказать что JSON-строка из которой парсится obj упорядочина как раз таки по необходимому значению.
Есть идеи?
Автор: nexus (не зарегистрирован), дата: 19 мая, 2011 - 00:14
#permalinkЗдравствуйте!
Никак не могу разобраться.
Вот есть у меня объект:
var defaults = {"size":"medium","title":"test"}; var json_elements= {};Есть такая функция:
var item = 0; function makeup(type){ var obj = defaults; obj.position = item; obj.position = type; json_elements[item] = obj; item++;Почему если вызвать функцию makeup() несколько раз с разным значением переменной type, то объект json_elements будет содержать несколько одинаковых (последний добавленый) объектов?!
И как это побороть?! Спасибо!
Автор: zenitchik (не зарегистрирован), дата: 7 июля, 2011 - 15:10
#permalinkif (x) { ... }Плохое решение.
x может быть равен 0, пустой строке, false в конце концов. В это случае проверка будет работать некорректно.
Надёжнее сравнивать с undefined
Автор: Gektar (не зарегистрирован), дата: 16 августа, 2011 - 23:10
#permalinkРебятки спасибо что есть у Вас такие полезные сайты!!!!
Автор: Гость (не зарегистрирован), дата: 22 августа, 2011 - 22:29
#permalinkvar Triangle;
(function () {
Triangle = function ( a, b, c ) {
this.sides = [ a, b, c ];
}
Triangle.prototype = new Shape();
Triangle.prototype.constructor = Triangle;
Triangle.prototype.getSquare = function () {
var p = this.getPerimeter()/2;
var S = Math.sqrt( p * ( p - this.sides[0] ) * ( p - this.sides[1] ) * ( p - this.sides[2] ) );
return Math.floor( S );
}
})();
var t = new Triangle ( 10, 15, 20 );
как мне получить имя класса из объекта t ???
Автор: Гость (не зарегистрирован), дата: 23 августа, 2011 - 11:47
#permalinkПоправте пример:
Автор: Dimka (не зарегистрирован), дата: 9 сентября, 2011 - 11:21
#permalinkПодскажите, пожалуйста, как посчитать количество ключей объекта?. В массивах можно посчитать размерность с помощью .length. В perl это можно сделать с помощью keys(). Можно ли это сделать без перебора ключей объекта (for ... in).
Автор: iyntx, дата: 19 сентября, 2011 - 01:05
#permalinkЗдесь так много написано и ни слова о том, что это такое и как это вообще может пригодиться...
Не могли бы дать несколько РАЗНЫХ примеров того что есть методы классы поля объекты наследования всякие public private prototype и прочие.
У нас же статья для того чтобы всем понятно было, а не только тем кто уже понял... Надеюсь на Ваше понимание...
Автор: Гость (не зарегистрирован), дата: 6 октября, 2011 - 13:22
#permalinkКак сделать так, чтобы при обращении к обьекту sum(4)(3) вывелась сумма 7
Автор: Questioner, дата: 1 ноября, 2011 - 16:14
#permalinkКак сделать приватное св-во? То есть которое можно получить из объекта, но не из вне объекта?
Автор: CE (не зарегистрирован), дата: 12 ноября, 2011 - 15:03
#permalink"Объект в javascript представляет собой обычный ассоциативный массив или, иначе говоря, "хэш". Он хранит любые соответствия "ключ => значение" и имеет несколько стандартных методов." - СПАСИБО!
Первое место (я где-то с десяток просмотрел до этого... наверное, не слишком удачно выбирал), где столь эссенциальная вещь прописана прямо и в самом начале.
Изучать я, соответственно, только-только начал, но вот когда видишь нечто вроде "ну вот, есть объекты, ну вот у них есть свои методы, алсо есть свойства" без дополнительных объяснений... Я уж грешным белом подумал, что это эдакие классы (с азартными играми и гулящими женщинами)
В общем - огромное спасибо. Один коротенький абзац, а столь радикально влияет на понимание сути. Впрочем, возможно, это применимо лишь ко мне - степень моей тупости британские ученые еще не вычислили, да.
Автор: Tipok, дата: 6 января, 2012 - 04:04
#permalinkКак это работает alert( ([][[]]+[])[+[]] ) и почему это буква "u" ???
Автор: DennisKa (не зарегистрирован), дата: 19 января, 2012 - 13:31
#permalinkОдно непонятно: если создать к примеру 1000 объектов, как потом найти 50, 100, 300, и уничтожить их. Или найти объекты по какому либо идентификатору (свойству "ID") например?
Автор: Игорь Л (не зарегистрирован), дата: 6 февраля, 2012 - 16:51
#permalinkПодскажите, как из js получить доступ к объекту формы, выраженной там в виде массива? Например, есть форма:
В PHP POST вполне нормально воспринимает переданный параметр как массив:
А как прочитать в JS?
Автор: Игорь Л (не зарегистрирован), дата: 6 февраля, 2012 - 18:40
#permalinkНашёл сам!
var a = document.getElementsByTagName('input'); var notcheck = true; for (var i = 0; i < a.length; i++) { var nam = a[i].name; if (a[i].type == 'checkbox' && nam.substr(0,5)=="idtyp") { if(a[i].checked) { notcheck = false; } } } if(notcheck) { request = getData("var","obj_notyp","",sess,""); alert(request); return(false); }Автор: alex385723 (не зарегистрирован), дата: 10 февраля, 2012 - 00:09
#permalinkПомогите решить следующую проблему!
Создал объект.
Пробегаю по массиву (не по объекту) циклом. Элементы массива содержат строку, которая обычно повторяется по много раз, иногда в массиве таких строк несколько разных.
Далее к объекту создается свойство содержащее массив из двух элементов - это в случае если данного свойства у объекта еще не существует, иначе заносится в новый массив, удаляется свойство и снова создается со значением нового массива, в который вкладывается следующий уровень (еще один новый массив) и т.д.
Таким образом должна получится схема такого типа:
Объект {
Свойство1: [строка, объект],
Свойство2: [строка, объект],
Свойство2: [[строка, объект],[строка, объект]]
Свойство2: [[строка, объект],[строка, объект],[строка, объект]]
Свойство3: [строка, объект]
Свойство4: [строка, объект]
...
}
Так вот там где многомерный массив, последний его элемент-массив недоступен. т.е. alert(Объект[свойство2]) выводит все кроме последнего вложенного массива (2).
Автор: zhenya (не зарегистрирован), дата: 2 марта, 2012 - 12:50
#permalinkПомогите новичку разобраться с обьектами. Правильно ли писать так как описано ниже?
function Rectangle(w, h) { (!w) ? this.width = 0 : this.width = w; (!h) ? this.heigth = 0 : this.heigth = h; }Rectangle.prototype.area = function() { if (this.width == 0 || this.heigth == 0) alert("error"); else return this.width * this.heigth; }Автор: Гость (не зарегистрирован), дата: 25 марта, 2012 - 05:42
#permalinkЗдравствуйте! Подскажите, как мне прочесть i-ый элемент массива для дальнейшего использования методом innerHTML?
Это не работает:
var arrText = new Array('Строка1','Строка2', ... ,'СтрокаN'); document.getElementById('Alert').innerHTML = arrText[i];В зависимости от значения "i" должен читаться соответствующий элемент массива "arrText".
Заранее спасибо!
Автор: Гость (не зарегистрирован), дата: 25 марта, 2012 - 09:59
#permalinkЛюди почему у меня не работает библиотека???
Файл wnd.js
//Window functions... var wnd = {}; wnd.new = function(name,content,val1,val2,ico,tit){ var id = Math.floor(Math.random() * 100); if(tit){ document.getElementById('wnd').innerHTML += "<div id="+id+" style=\"position:absolute;top:"+val1+"px;left:"+val2+"px;background-color:#ff6600;\"><fieldset><legend><img src='"+ico+"' title=\"Открыть/Закрыть кнопки\" height=20 width=20 onClick=\"if(document.getElementById('"+id+"b').style.display == 'none'){document.getElementById('"+id+"b').style.display = 'inline';}else{document.getElementById('"+id+"b').style.display = 'none';}\"><span id='"+id+"b' style=\"display:none;\"><span onClick=\"wnd.close("+id+")\" title=\"Закрыть\">(X)</span><span title=\"Свернуть\" onClick=\"wnd.fold("+id+",'"+ico+"','"+name+"')\">(_)</span><span onClick=\"wnd.repos('"+id+"');\" title=Переместить>(+)</span></span>"+name+"</legend>"+content+"</fieldset></div>"; return id; } else{ } document.getElementById('wnd').innerHTML += "<div id="+id+" style=\"position:absolute;top:"+val1+"px;left:"+val2+"px;background-color:#ff6600;\">"+content+"</div>"; return id; }; wnd.close = function(id){ document.getElementById(id).innerHTML = ''; }; wnd.closeall = function(){ document.getElementById('pmenu').innerHTML = ''; document.getElementById('wnd').innerHTML = ''; }; wnd.fold = function(id,ico,name){ document.getElementById(id).style.display = 'none'; document.getElementById('pmenu').innerHTML += "<span id='"+id+"f'> | <img src='"+ico+"' height=20 width=20 onClick=\"if(document.getElementById('"+id+"fm').style.display == 'none'){document.getElementById('"+id+"fm').style.display = 'inline'}else{document.getElementById('"+id+"fm').style.display = 'none'}\" title=\"Открыть/Закрыть кнопки\"><span id='"+id+"fm' style=\"display:none;\"><span onClick=\"wnd.close("+id+");document.getElementById('"+id+"f').innerHTML = '';\" title=\"Закрыть\">(X)</span> | <span onClick=\"document.getElementById("+id+").style.display = 'inline';document.getElementById('"+id+"f').innerHTML = '';\" title=\"Развернуть\">([])</span></span><span onClick=\"document.getElementById("+id+").style.display = 'inline';document.getElementById('"+id+"f').innerHTML = '';\">"+name+"</span></span>"; }; wnd.repos = function(id){ x = prompt('Введите координату X:',document.getElementById(id).style.left); y = prompt('Введите координату Y:',document.getElementById(id).style.top); document.getElementById(id).style.top = y; document.getElementById(id).style.left = x; }; }Файл wnd.html
<html> <head> <title>Библиотека wnd.js</title> <script src=wnd.js></script> </head> <body> <div id=wnd style="position:absolute"></div> <div id=pmenu></div> <button onClick="wnd.new('Привет','Привет!',0,0,'',1);">Открыть окно</button> </body> </html>Вообще ничего не понять(((
Автор: Гость (не зарегистрирован), дата: 21 апреля, 2012 - 17:35
#permalinkБиблиотека wnd.js
Открыть окно
Автор: Гость (не зарегистрирован), дата: 25 мая, 2012 - 15:33
#permalinkСоздать массив из M элементов. М вводят с клавиатуры с прорверкой (оно должно быть не менее 12). Заполнить числовыми значениями с клавиатуры. Вывести на экран. Вывести позицию первого из элементов, который имеет значение, превышающее 50.
Как выполнить?
Автор: Гость (не зарегистрирован), дата: 31 мая, 2012 - 23:08
#permalinkПочему не срабатывает метод объекта?
например объект:
var object = { show:function (obj)// считывает список сообщений { alert(obj.tagName); } }вызываем так:
Если передавать в onClick функции то все нормально
Автор: Bandicoot, дата: 27 июля, 2012 - 13:20
#permalinkДавно хотел спросить, почему при переборе в цикле не работает получение значения свойства объекта по точке:
var obj = {foo: "bar", a: 42}; for (var prop in obj) { console.log(obj.prop); } // выведет undefined, в то время как obj[prop] корректно выведет значенияАвтор: Mefistofel (не зарегистрирован), дата: 10 ноября, 2012 - 20:24
#permalinkОбъясните кто-нибудь, не понимаю для чего нужна эта строчка:
vasya.sayName = sayName// один и тот же метод в двух объектах
petya.sayName = vasya.sayName
Не понимаю что вообще делается в этих строчках и для чего они необходимы?
Автор: Гость (не зарегистрирован), дата: 12 ноября, 2012 - 17:25
#permalinkВ статье рассказывается про перебор ключа и значения объекта а как осуществить пребор если объект вида obj={a:5,b:{c:7},d:3};
Автор: Гость (не зарегистрирован), дата: 15 ноября, 2012 - 11:27
#permalinkКомментарий: *
Автор: BlaMe (не зарегистрирован), дата: 27 марта, 2013 - 11:36
#permalinkfunction replace_string(j1,j2,j3){
var f=0;
var it='';
it = it + j1;
f=it.indexOf(j2);
while (f!=-1){
f=it.indexOf(j2);
if (f>0){
it = it.substr(0,f) + j3 + it.substr(f+j2.length);
};
};
return it
};
old_str ="Федоров Федор Федорович";
new_str= replace_string(old_str,"е","Е");
alert(new_str);
парни как тут вывести дополнительную строку которая бы выводила количество алгоритмов совершенных в этой функции а именно замен букв с маленьких до больших)
Автор: Гость (не зарегистрирован), дата: 26 августа, 2013 - 17:35
#permalinkСкажите пожалуйста почему может в QML такая конструкция не возвращает true в условии? Этот вызов происходит в рекурсивной функции. Если производить доступ на одном уровне итерации, то все окей, а если на следующем, то пишет, что нет такого свойства. Хотя оно было добавлено на предыдущих итерациях.
var key = item.toString().match(/\((.*?)\)/)[1]
//console.log(key)
if (key in group) {
console.log("EXIST")
} else {
//console.log("ADD")
group[key] = 1
}
Автор: FANTOM22A, дата: 22 января, 2014 - 02:05
#permalinkvar o = {a:5, b:true}
for (var key in o) {
alert(key+':'+o[key])// почему так +o.key вместо значения undefined выводят?
}
Автор: @@@D@@@, дата: 29 марта, 2014 - 18:03
#permalinkПодскажите пожалуйста, как для объекта String добавить метод isAlnum(), который возвращает true если строка состоит только из букв латинского алфавита или цифр, и false - в противном случае???
Автор: Stanly (не зарегистрирован), дата: 22 октября, 2014 - 13:55
#permalinkВ разделе 'Добавление свойств'
в примере:
var name = 'test'
o[name] = 5
ошибка. Вместо o[name] нужно писать o['test'].
Автор: наташа.гость (не зарегистрирован), дата: 16 декабря, 2015 - 13:27
#permalinkdocument.getElementById('output').innerHTML = 'x1 = '+print((-B+Math.sqrt(D))/A, 0)+'x2 = '+print((-B-Math.sqrt(D))/A, 0);
else
document.getElementById('output').innerHTML = 'x1 = '+print(-B/A,Math.sqrt(-D)/A)+'x2 = '+print(-B/A,-Math.sqrt(-D)/A);
почему значение х выводится через запятую?
как это объяснить??
например :
х1=(0.6,0.3)
х2=(-0.2,0.4)
Автор: Гость (не зарегистрирован), дата: 9 января, 2016 - 05:06
#permalinkСледующие два варианта создания объекта эквивалентны:
// эквивалентные записи
var o = new Object()
var o = {}
Реально не эквивалентны:
var o = new Object() - если объект существовал ранее и у него были определены свойства, то эти свойства продолжают существовать.
var o = {} - здесь при создании объект пустой, без свойств.
Автор: AlinaR (не зарегистрирован), дата: 12 марта, 2020 - 19:22
#permalinkЯ не могу решить эту задачу. Пожалуйста помогите мне
var recipe = { // значения являются количеством этого ингредиента
potato: 3,
onion: 1,
corn: 5
};
var store = { // значениями являются цены за ингредиент
cheese: 8,
corn: 3,
meat: 6,
};
function costOfRecipeInStore(recipe, store) {
??? //Возврат затрат в магазин
}