Javascript.RU

Объекты 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 object

Как и в других языках, у объектов 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();


Автор: klubben (не зарегистрирован), дата: 7 июня, 2008 - 12:13
#permalink

Извиняюсь, сам дурак


Автор: anima (не зарегистрирован), дата: 19 июня, 2008 - 13:51
#permalink

Хорошие статьи. Коротко, самое важное, без утаревших приемов, и всякой лабуды. Но я, собственно, по поводу Доступ к объекту из метода.
Раньше, было не нужно, а сейчас потребовалось, из повешанного на объект метода, получить ссылку не на объект его вызвавший, а на объект, на котором висит сам метод. Вроде вот он рядом :-), а как достать? Понимаю, что можно использовать прототип, но это нарушит всю задуманную задачу. Перекопал сегодня пол Интернета, но как то не смог ни чего найти. Такое чувство, что есть какая то простейшая возможность, но я её упустил.
Сам метод генерится динамически, и я, в принципе, могу жестко забить ссылку на объект, но это вроде не этично. :-)


Автор: vasa_c, дата: 21 июня, 2008 - 19:59
#permalink

Что есть "объект, на котором висит сам метод"?


Автор: anima (не зарегистрирован), дата: 20 июля, 2008 - 11:03
#permalink

Что есть "объект, на котором висит сам метод"?

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

Например, есть элемент div c id="div", вешаем метод таким образом:

document.getElementById('div').metod = function() { alert('Ok!'); };

потом назначаем этот метод обработчиком события click.

document.get.ElementsByTagName('body')[0].onclick = document.getElementById('div').metod;

Так "не принято", но мне нужно именно так.

И теперь, нужно из самого метода получить ссылку на DIV, на котором он висит.


Автор: Гость (не зарегистрирован), дата: 31 июля, 2008 - 22:38
#permalink
document.get.ElementsByTagName('body')[0].onclick = function()
{
    document.getElementById('div').metod;
}

Автор: Илья Кантор, дата: 19 августа, 2008 - 12:34
#permalink

В тему: в javascript, в отличие от C/Java/... методы НЕ висят на объектах. Контекст вызова метода целиком зависит от того, как его вызвали.

Вот


Автор: Гость (не зарегистрирован), дата: 30 июня, 2008 - 11:21
#permalink

как можно исползоват функции php в javascript


Автор: Гость (не зарегистрирован), дата: 6 июля, 2008 - 21:00
#permalink

РНР это серверные скрипты... JavaScript это клиентская часть. Можно вызвать через AJAX сам РНР скрипт и результат его работы получить через XML (или в HTML на худой конец). А дальше делай с этими данными все что нужно.


Автор: Руслан Зетов (не зарегистрирован), дата: 29 августа, 2010 - 13:36
#permalink

Думаю гораздо удобней будет получить результат ввиде JSON строки.


Автор: Гость (не зарегистрирован), дата: 16 июня, 2020 - 22:15
#permalink

for sure! I agree. Thanks for these details. fence company cedar rapids


Автор: Гость (не зарегистрирован), дата: 16 июня, 2020 - 22:22
#permalink

Автор: Bratok (не зарегистрирован), дата: 15 августа, 2008 - 18:08
#permalink

А можно ли изменит порядок свойств объекта? Можно ли с объектом работать как с массивом т.е. использовать теже методы предусмотренные для объект Array?


Автор: Bratok (не зарегистрирован), дата: 17 августа, 2008 - 08:01
#permalink

Ну, ладно с предыдущим вопросом я разобрался. Ввод: нельзя. Другой ворос, можноли получить как-нибудь ссылку на свойство объекта, именно ссылку.


Автор: Гость (не зарегистрирован), дата: 18 августа, 2008 - 18:41
#permalink

интересная статья. Много полезного узнал. Но вот интересно как можно вызывать метод объекта через setTimeout? Странно, вызов происходит, только метод не может получить доступ к свойствам объекта.


Автор: Илья Кантор, дата: 18 августа, 2008 - 22:33
#permalink

В примере ниже вызван метод объекта "metod" с правильным this

....
var self = this
setTimeout(function() { self.method() }, 1000)
...

То есть, правильный указатель this передается через замыкание. Очень распространенный трюк.


Автор: Алексей_Р (не зарегистрирован), дата: 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)+'&')  }

?


Автор: Zeroglif, дата: 14 марта, 2009 - 23:51
#permalink

Array - это один объект (конструктор/функция), а Array.prototype - это другой объект, у каждого свои свойства, которые могут иметь атрибут DontEnum, что исключает их перечисление.


Автор: kefi, дата: 15 марта, 2009 - 11:56
#permalink

Хорошо, поправлюсь :

Вначале наведенные ответом вопросы : а как понять(узнать), какие атрибуты установлены у данного свойства ? И как вообще установить эти атрибуты ?

И собственно сам вопрос :
Если Array является объектом (встроенным) со свойствами constructor,length,prototype,concat,join etc..., то почему я получаю эти свойства у его прототипа, а не у него самого :

alert(Array.prototype.hasOwnProperty("join") ) // -1
 alert(Array.hasOwnProperty("join"))                //  0

Тем более, что сказано в документации :
Этот метод не проверяет наличие свойства по цепочке прототипов; указанным свойством должен обладать именно сам объект. А пример выше показывает, что именно сам объект не обладает свойством, а обладает, наоборот, - прототип.
Короче , путаница получается - распутайте, плз.

Еще пример для размышления :

alert(Object.hasOwnProperty("prototype")) // -1
 alert(Object.prototype.hasOwnProperty("prototype")) // 0

Автор: Гость (не зарегистрирован), дата: 28 декабря, 2015 - 06:08
#permalink

wadadadadadadadadadadadadadadadadadadadadadadadadadadadadadadad


Автор: bruno555 (не зарегистрирован), дата: 21 августа, 2024 - 15:57
#permalink

The site also provided several promotions, including a welcome bonus for new players. Their mobile app was user-friendly, allowing me to enjoy games from anywhere. For a great online casino experience, choose https://bruno-casino-fr1.fr/ a platform with diverse game options and strong promotional offers. My initial exploration was both fun and eye-opening, offering a fresh perspective on online gaming.


Автор: rowen44zz421111111 (не зарегистрирован), дата: 21 августа, 2024 - 16:04
#permalink

The casino site also had attractive promotions, including a match deposit bonus for new players and loyalty rewards. Their mobile app was well-optimized, making it easy to play on the go. For those https://sultankazino.kz/ new to online casinos, starting with a site that offers a variety of themes and live game options can enhance the experience. My first foray into online casinos was both fun and informative, providing a fresh perspective on gaming.


Автор: Илья Кантор, дата: 15 марта, 2009 - 14:50
#permalink

Обратитесь к стандарту: http://javascript.ru/ecma/part12#a-12.6.4.

Там описано, как работает цикл for .. in. Обратите внимание на шаг 5.

Перечисляются только те свойства, у которых нет атрибута DontEnum.

Большинство свойств у родных объектов яваскрипт имеют DontEnum, и поэтому не будут перечисляться в цикле for..in.

Атрибут DontEnum не проверяется при прямом обращении, поэтому Array.prototype.join выдаст, что метод все-таки есть.


Автор: 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),


Автор: Илья Кантор, дата: 15 марта, 2009 - 19:23
#permalink

У класса Array есть свой, "статический", метод join:

Array.join([1,2,3],"-")

Автор: Леонид Евстигнеев, дата: 31 мая, 2009 - 18:43
#permalink

И в чём принципиальная разница между a и b в следующем коде.

var a = new Object();
function myFunc(){};
var b = new MyFunc();

Я так понимаю ссылкой prototype (или [[prototype]]) и как следствие набором свойств и методов. Или ещё чем...? И можно ли сказать, что b создается как и а, но после создания b вызывается ещё и MyFunc() (с this указывающем на b)


Автор: Гость (не зарегистрирован), дата: 4 июля, 2009 - 14:09
#permalink

Как я полагаю, Вы сами ответили на свой вопрос. Мне кажется, что все именно так.


Автор: marryjoy6374 (не зарегистрирован), дата: 8 января, 2024 - 11:59
#permalink

Я так понимаю ссылкой prototype (или [[prototype]]) и как следствие набором свойств и методов. Или ещё чем Different Versions:
heardle game: This version focuses on music from different decades.
Videogame Heardle: Features snippets from video game music.
Thanks


Автор: dido (не зарегистрирован), дата: 20 декабря, 2009 - 13:56
#permalink

Very good post, thanks a lot.


Автор: 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.: заранее приношу ивинения, если пишу не туда.
Я "чайник"


Автор: Гость (не зарегистрирован), дата: 30 января, 2010 - 10:33
#permalink

<html>
<head>
<title></title>
</head>
<body>
<ul id="list">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</body>
</html>

<script type="text/javascript">
var getId = document.getElementById("list");
function clickFunction(elemId){
alert(elemId.id);
}
var altF = new clickFunction(getId);
</script>


Автор: sarlv (не зарегистрирован), дата: 17 января, 2010 - 03:02
#permalink

Прошу прощения, читать так:
alert(elemId.nodeName);


Автор: Гость (не зарегистрирован), дата: 30 января, 2010 - 10:22
#permalink
  • Item 1
  • Item 2
  • Item 3

var getId = document.getElementById("list");
function clickFunction(elemId){
alert(elemId.id);
}
var altF = new clickFunction(getId);


Автор: caf1zz2axug (не зарегистрирован), дата: 21 августа, 2024 - 17:09
#permalink

Next, I ventured into the live casino area and tried live dealer roulette. Though I had a basic understanding of https://casino-arlequin-france.com/ roulette, the live dealer experience was entirely new. Watching the wheel spin in real-time and interacting with the dealer provided a more immersive and engaging experience. The dealer’s professional approach and the real-time action made the game feel more authentic and thrilling.


Автор: PieceOfMeat (не зарегистрирован), дата: 29 марта, 2010 - 16:12
#permalink

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

И было бы интересно увидеть функцию clone, которая делала бы копирование объектов по значению.


Автор: B@rmaley.e><e, дата: 30 марта, 2010 - 22:41
#permalink

function clone(obj){
var newObj = {}, i;
for(i in obj)
newObj[i] = obj[i];
return newObj;
}

TODO: Добавить рекурсивое клонирование


Автор: Илья Кантор, дата: 28 мая, 2010 - 16:49
#permalink

В этой функции есть ряд недостатков, аккуратнее с ней.


Автор: Евгений Z (не зарегистрирован), дата: 16 ноября, 2011 - 17:51
#permalink

Доброго времени суток. Хотел спросить совет знающих людей. Есть страничка с несколькими фреймами. Тянуть jQuery в каждый фрейм не хочется, т.к. это потянет за собой увеличение трафика. Хотелось узнать, можно ли каким-то образом подключить jQuery в главной страничке и использовать его в страничках-фреймах? Разумеется конструкция типа var $ = top.$; не прокатит т.к. передается ссылка на обьект а не он сам. Пробовал функции клонирования - аналогичная ситуация. Ни в первом ни во втором случаях из $ не видно локальных функций, которые описаны во фреймах, но jQuery работает (тот же ajax). Так вот вопрос, можно ли найти выход из данной ситуации? Ну очень не хочется в каждом фреймне тянуть jQuery (((


Автор: Гость (не зарегистрирован), дата: 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?


Автор: Илья Кантор, дата: 28 мая, 2010 - 16:49
#permalink

Обращение к свойствам объекта из метода без this невозможно.


Автор: Ryan443 (не зарегистрирован), дата: 21 августа, 2024 - 18:03
#permalink

Ryan also took advantage of the casino’s promotional offers, such as deposit bonuses and weekly reloads. He found the mobile app to be reliable and convenient, allowing him to enjoy his favorite games https://machancecasino-france.com/ on the go. His experience highlights the importance of exploring both engaging slot games and live dealer options, as well as taking advantage of promotions to enhance the online casino experience.


Автор: Александр второй (не зарегистрирован), дата: 29 мая, 2010 - 17:53
#permalink

Не нашел на сайте, где можно посмотреть как можно сделать так чтобы при наведении мыши на страницу происходило какое-то действие. Подскажите.


Автор: Гостейко (не зарегистрирован), дата: 26 октября, 2010 - 14:05
#permalink

?


Автор: Гостейко (не зарегистрирован), дата: 26 октября, 2010 - 14:06
#permalink
<body onmouseover="someFunction()"> ?

Автор: гость (не зарегистрирован), дата: 21 июля, 2010 - 15:08
#permalink

Извиняюсь за глупый вопрос)

var o = {} //создали объект
o['test'] = 5 //добавили свойство
alert(o['test']) //выводит 5

Подскажите почему если вместо alert(o['test']) прописать alert(o.test) то будет выведено undefined. Ведь сказано что o - это объект, а test - его свойсто. Тоесть у него же есть свойство.


Автор: Гость (не зарегистрирован), дата: 22 августа, 2010 - 22:00
#permalink
[js]
[js]
[js]
[js]
[js]
[js]
[js]
[js]
[/js][/js][/js][/js][/js][/js][/js][/js]

Автор: mch (не зарегистрирован), дата: 23 августа, 2010 - 10:28
#permalink

Если я создаю объект с несколькими свойствами и присваиваю в качестве значений, например, Image при создании объекта в память будет загружены изображения для каждого указанного свойства или свойствам будут присвоены только ссылки на Imagе. Т.е. интересует вопрос выделения памяти под объект в этом случае.

var img = new Image ();
img.src = "a.jpg";

var o = { b1: img, b2: img, b3: img }


Автор: Emily88 (не зарегистрирован), дата: 21 августа, 2024 - 17:55
#permalink

As Emily grew more comfortable with slots, she decided to try live dealer games. She selected live dealer poker, fascinated by the strategic elements and the opportunity to interact with a real dealer. The https://joker8casino-fr.com/ live dealer experience provided a more immersive and engaging environment, enhancing her enjoyment of the game.

Emily also made use of the casino’s promotions, including reload bonuses and seasonal offers. The mobile app was seamless and allowed her to play conveniently from her phone. Her story highlights the benefits of exploring different game types, from engaging slots to interactive live dealer games, to fully enjoy the online casino experience.


Автор: Гость (не зарегистрирован), дата: 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 метров


Автор: Андрей99999999999 (не зарегистрирован), дата: 10 апреля, 2012 - 19:31
#permalink

Допиши ..., а между ними вставь код)


Автор: 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(); // !!!

Как мне сделать чтобы второй вариант работал как первый (извините, иначе сформулировать не смог :-) ) Тоесть чтобы во втором случае обьект создался как в первом, что ли


Автор: Гость (не зарегистрирован), дата: 10 октября, 2010 - 10:34
#permalink

Упс, опечатался. Должно быть так:

myobj.prototype.f = function() { alert(this.a); }

Автор: 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:

  1. var classA = function(){
  2. }
  3. var a = new classA();
  4. var b = new classA();
  5. var z = new Date();
  6. for (var k in window) {
  7. if (typeof (window[k]) == "object" && window[k] instanceof classA) {
  8. alert('Variable ' + k + ' is a classA');
  9. }
  10. }

В опере и хроме скрипт отрабатывает правильно, находит переменные 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?


Автор: Pruvet (не зарегистрирован), дата: 28 декабря, 2010 - 20:01
#permalink

опечатка:
вместо

thisl.getDelay

читать:

this.getDelay

Автор: 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'};

выводит то что нужно, но насильно пихать, а потом срезать "лишние" символы не очень то и хочется


Автор: Тимур Галаров (не зарегистрирован), дата: 18 июня, 2021 - 17:08
#permalink

Спасибо, полезное можно узнать на вашем форуме всегда. А я как раз начинающие програмист


Автор: 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 и через точку?


Автор: Гость (не зарегистрирован), дата: 15 января, 2011 - 11:43
#permalink

забыл про new?


Автор: frankbakulov (не зарегистрирован), дата: 15 января, 2011 - 18:12
#permalink

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

Вот это очень правильное замечание!

Только что на это наткнулся и испытал неприятное удивление - был уверен, что в js, как в нормальных языках, оператор "=" присваивает правую часть левой И БОЛЬШЕ НИЧЕГО.

Считаю, статья должна начинаться с этого.


Автор: ReptatmogeVog (не зарегистрирован), дата: 3 февраля, 2011 - 16:23
#permalink

да, что-то на подобии этого


Автор: Zeran (не зарегистрирован), дата: 16 марта, 2011 - 17:58
#permalink

Все никак не разберусь, как реализовано в jQuery такое:

$("myDiv").html()

Как сделать свои функцию в функции?


Автор: zeran (не зарегистрирован), дата: 17 марта, 2011 - 12:41
#permalink

Можно, конечно, сделать просто:

object.prototype.html = function() { return this.innerHTML };

например так. Но тогда это будет касаться всех объектов, что не очень удобно. ((


Автор: Гость (не зарегистрирован), дата: 29 марта, 2011 - 11:58
#permalink

Хочу "переименовать" id объекта через
document.getElementById( "sId").id = "sNewId";

Все работает, за исключением случая когда объект является активным объектом документа (т.е. имеет фокус). Другими словами переименование НЕ проходит с объектами, которые имеют во время выполнения скрипта фокус.

Как решить?


Автор: mrGreed, дата: 1 апреля, 2011 - 11:08
#permalink

проверять фокус - снимать фокус - менять айди - вешать фокус..?


Автор: mrGreed, дата: 1 апреля, 2011 - 11:06
#permalink

Дабавлю баянчик про хорошую статью .. Действительно - огромное спасибо автору(ам) за проект.
К делу. у Меня есть объект типа

{"<уникальный числовой код":["<значение1>","<значение2>",..],-||-,..}

проблема в том, что стандартным выводам

for(key in obj)

создаются 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
#permalink
if (x) { ... }

Плохое решение.
x может быть равен 0, пустой строке, false в конце концов. В это случае проверка будет работать некорректно.
Надёжнее сравнивать с undefined


Автор: Гость (не зарегистрирован), дата: 15 августа, 2011 - 00:14
#permalink

Интересно сколько травы выкурили те кто придумали этот язык. Более не очевидного я в своей жизни не встречал. Ассемблер лично для меня намного проще.


Автор: B@rmaley.e><e, дата: 15 августа, 2011 - 18:49
#permalink

Brainfuck тоже прост. Вот только простота != выразительность.


Автор: Гость (не зарегистрирован), дата: 6 апреля, 2013 - 18:48
#permalink

полностью согласен!Асм легче


Автор: Gektar (не зарегистрирован), дата: 16 августа, 2011 - 23:10
#permalink

Ребятки спасибо что есть у Вас такие полезные сайты!!!!


Автор: Гость (не зарегистрирован), дата: 22 августа, 2011 - 22:29
#permalink

var 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

Поправте пример:

Для этого используется ключевое слово this:

for(var key in obj) {

… obj[key] …

}


Автор: Dimka (не зарегистрирован), дата: 9 сентября, 2011 - 11:21
#permalink

Подскажите, пожалуйста, как посчитать количество ключей объекта?. В массивах можно посчитать размерность с помощью .length. В perl это можно сделать с помощью keys(). Можно ли это сделать без перебора ключей объекта (for ... in).


Автор: max0n, дата: 9 октября, 2014 - 17:54
#permalink

alert(Object.keys(o)); // o - объект, которого нужны свойства


Автор: 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" ???


Автор: Гость (не зарегистрирован), дата: 14 декабря, 2013 - 08:00
#permalink

Тут все просто, хоть и похоже на brain f#ck.
Отдельно стоящий оператор +[] - это 0

получается ([][[]]+[])[+[]] -> ([][[]]+[])[0]

([][[]]+[]) - это строка "undefined"

([][[]]+[])[0] -> "undefined"[0] -> "u"

Тут самое сложное понять как преобразуется значение undefined в строку "undifined"

[][[]] - значение undefined - тип undefined
([][[]]+[]) - значение "undefined" - тип "string"

Так можно много экпериментировать.
Например:
(+[][+[]]+[])[+[]+[]] = "N"

+[]+[] -> 0+0 -> 0
(+[][+[]]+[]) -> "NaN"

"NaN"[0] -> "N"

Может сумбурно и не последовательно объяснил, но все именно так работает.


Автор: DennisKa (не зарегистрирован), дата: 19 января, 2012 - 13:31
#permalink

Одно непонятно: если создать к примеру 1000 объектов, как потом найти 50, 100, 300, и уничтожить их. Или найти объекты по какому либо идентификатору (свойству "ID") например?


Автор: Игорь Л (не зарегистрирован), дата: 6 февраля, 2012 - 16:51
#permalink

Подскажите, как из js получить доступ к объекту формы, выраженной там в виде массива? Например, есть форма:

<form method="post">
<label><input type="checkbox" name="idtyp[1]">typ 1</label>
<label><input type="checkbox" name="idtyp[2]">typ 2</label>
<label><input type="checkbox" name="idtyp[3]">typ 3</label>
</form>

В PHP POST вполне нормально воспринимает переданный параметр как массив:

$idtyp = $_POST['idtyp'];

А как прочитать в 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".

Заранее спасибо!


Автор: Гость (не зарегистрирован), дата: 21 апреля, 2012 - 17:41
#permalink

попробуй

var arrText =['Строка1','Строка2', ... ,'СтрокаN'];
document.getElementById('Alert').innerHTML = arrText[i];

Автор: Гость (не зарегистрирован), дата: 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:43
#permalink
<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.

Как выполнить?


Автор: maksimr, дата: 26 мая, 2012 - 17:03
#permalink

Возможно это решение подойдет.

(function() {
    var size = prompt('Пожалуйста введите размер массива'),
        findBigNumber = function(arr) {
            var i = 0,
            len = arr.length, result;

            for (; i < len; i++) {
                if (parseInt(prompt('Введите значение элемента ' + i),10) > 50) {
                    result = result || i;
                }
            }
            return result || 'К сожалению в последовательности нет элемета со значением превышающим 50';
        };

    size = parseInt(size, 10);
    if (isNaN(size) || size < 12) {
        return alert('Длина массива должна быть больше либо равна 12');
    }

    collection = new Array(size);
    alert(findBigNumber(collection));
}());

Автор: Гость (не зарегистрирован), дата: 31 мая, 2012 - 23:08
#permalink

Почему не срабатывает метод объекта?
например объект:

var object = {
 	show:function (obj)// считывает список сообщений
	{	
	  alert(obj.tagName);
	}
}

вызываем так:

<li  onClick="object.show(this)">first</li>

Если передавать в 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] корректно выведет значения

Автор: Дзен-трансгуманист, дата: 28 июля, 2012 - 00:44
#permalink

Laugh
Да потому что обращение к свойству напрямую через точку (obj.prop) равносильно скобочной записи со строковым литералом (obj["prop"]):

var obj = { foo: "bar", a: 42, prop: "я ничего не понимаю в операторах доступа" };
for (var prop in obj) {
  alert(obj.prop);
}

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


Автор: chlp (не зарегистрирован), дата: 2 июля, 2015 - 16:30
#permalink

Выводит undefined, т.к. обращаясь к obj.prop, вы обращаетесь к obj['prop'].


Автор: Mefistofel (не зарегистрирован), дата: 10 ноября, 2012 - 20:24
#permalink

Объясните кто-нибудь, не понимаю для чего нужна эта строчка:
vasya.sayName = sayName

// один и тот же метод в двух объектах
petya.sayName = vasya.sayName

Не понимаю что вообще делается в этих строчках и для чего они необходимы?


Автор: Родион Николаевич Юрьев (не зарегистрирован), дата: 3 мая, 2013 - 11:22
#permalink

А что тут такого? Методов я не вижу, есть два объекта со свойствами.
Существует объект vasya. У него, возможно, существует свойство sayName (его можно создавать и динамически). Этому свойству присваивается значение sayName.
Теперь мы берём другой свойство другого объекта petya.sayName и присваиваем ему значение свойства vasya.sayName. Важно, что здесь присвоение осуществляется не по ссылке. То есть, если мы после этого изменим vasya.sayName, то petya.sayName - не изменится.


Автор: Гость (не зарегистрирован), дата: 12 ноября, 2012 - 17:25
#permalink

В статье рассказывается про перебор ключа и значения объекта а как осуществить пребор если объект вида obj={a:5,b:{c:7},d:3};


Автор: Родион Николаевич Юрьев (не зарегистрирован), дата: 3 мая, 2013 - 11:24
#permalink

Это делается вложенными циклами, либо, если заведомо известно, что вложенный объект не нужно итерировать, то добавляем условную конструкцию и когда доходим до такого объекта, что-то там отдельно делаем и идём дальше по циклу.


Автор: Игорь Кожанов (не зарегистрирован), дата: 18 июня, 2021 - 17:10
#permalink

Вложенные циклы - это уже устаревший стандарт. Сейчас все по другому делается. Криптозащита и все такое


Автор: Гость (не зарегистрирован), дата: 15 ноября, 2012 - 11:27
#permalink

Комментарий: *


Автор: BlaMe (не зарегистрирован), дата: 27 марта, 2013 - 11:36
#permalink

function 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
#permalink

var 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
#permalink

document.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 = {} - здесь при создании объект пустой, без свойств.


Автор: Гость (не зарегистрирован), дата: 13 июня, 2018 - 20:42
#permalink

Да, они эквиваленты, можно статьи про js посмотреть.


Автор: 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) {
??? //Возврат затрат в магазин
}


Автор: Гость (не зарегистрирован), дата: 28 июня, 2024 - 07:24
#permalink

With a diverse range of levels, geometry dash ensures there's always something new and exciting to discover.


Автор: Гость (не зарегистрирован), дата: 21 июля, 2024 - 04:16
#permalink

Synergy between music and gameplay creates a captivating symphony of challenge and rhythm in red ball


Автор: Sophie Miller (не зарегистрирован), дата: 11 сентября, 2020 - 18:16
#permalink

Salutations! Je suis désolé, ce n'est pas le sujet! J'aime vraiment votre forum! Je vous remercie, je suis avec vous)
dll


Автор: Sophie Miller (не зарегистрирован), дата: 13 ноября, 2020 - 21:40
#permalink

Hello! this complex question. Here it is necessary to think...
192.168.0.1


Автор: Sophie Miller (не зарегистрирован), дата: 13 декабря, 2020 - 15:01
#permalink

Os doy las gracias por la información! Yo estaba buscando y no podía encontrar. Usted me ayudó!
pay pal customer service number


Автор: rgtbgb (не зарегистрирован), дата: 5 февраля, 2021 - 10:21
#permalink

192.168.l.254
Nous vous remercions de votre travail sur le blog! Vous faites un bon travail!


Автор: Sophie Miller (не зарегистрирован), дата: 16 февраля, 2021 - 20:20
#permalink

Witaj! Przepraszam, to nie jest temat! Naprawdę lubię twoje forum! Dziękuję, jestem z tobą)
192.168.l.l


Автор: Тимур Орлов (не зарегистрирован), дата: 26 февраля, 2021 - 15:36
#permalink

Спасибо. Все толково рассписано. Давно искал такое пояснение, недавно сделал новый портал , жд билеты онлайн продажа и что то то не совсем правильно в коде сделал - возврат билетов не работал. Как раз именно перебор переменных криво прописан был. Теперь все ОК

Удачи в разработках


Автор: Mature Sex Chat (не зарегистрирован), дата: 3 июня, 2021 - 19:04
#permalink

Mature Sex Chat is the best web place for lonley guys in UK to find fine girls for hot chat


Автор: Бастар (не зарегистрирован), дата: 18 июня, 2021 - 17:06
#permalink

Все так и есть на самом деле но с оговорками


Автор: Гость (не зарегистрирован), дата: 12 апреля, 2022 - 17:18
#permalink

Автор: Гость (не зарегистрирован), дата: 16 апреля, 2022 - 14:44
#permalink

Автор: Ufa1688 (не зарегистрирован), дата: 14 июня, 2022 - 12:31
#permalink

Israel withdrew ufa1688 from Gaza in 2005 but, ufabet เข้า สู่ระบบ with the help of Egypt, clamps 1688.com down on the borders of the ทางเข้า Ufa 1688 enclave now governed by แทงบอลออนไลน์ Hamas Islamists. Dream Gaming Palestinian Big gamingauthorities have limited self-rule ลิงค์รับทรัพย์ in the West Bank บาคาร่าwhich is dotted หวยออนไลน์with Israeli settlements.


Автор: jerkyford (не зарегистрирован), дата: 29 декабря, 2022 - 11:35
#permalink

Everything is meticulously planned. I've been looking for an explanation like this for a long time, and I recently launched a new portal. penalty kick online


Автор: 카지노사이트 (не зарегистрирован), дата: 16 января, 2023 - 05:36
#permalink

This is the post I was looking for. I am very happy to read this article. If you have time, please come to my site 카지노사이트 and share your thoughts. Have a nice day.


Автор: 바카라사이트 (не зарегистрирован), дата: 16 января, 2023 - 07:00
#permalink

I am very impressed with your writing 바카라사이트 I couldn't think of this, but it's amazing! I wrote several posts similar to this one, but please come and see!


Автор: 토토사이트순위 (не зарегистрирован), дата: 6 марта, 2023 - 12:07
#permalink

Your ideas inspired me very much. 토토사이트순위 It's amazing. I want to learn your writing skills. In fact, I also have a website. If you are okay, please visit once and leave your opinion. Thank you.


Автор: BETFLIXSUPERVIP (не зарегистрирован), дата: 15 марта, 2023 - 19:34
#permalink

betflix new นำความโชคดีของท่านมาลงกับ สล็อตออนไลน์ของเราสิ betflixsupervip ด้วยเกมที่หลากหลายให้เล่น แนวเกมส์ที่สนุก พร้อมที่จะบริการลูกค้าทุกท่านให้ไปได้ไกลที่สุด แตกล้านจ่ายล้าน แน่นอนมั่นใจที่นี่ที่เดียว betflixsupervip.com


Автор: James Morgan (не зарегистрирован), дата: 20 марта, 2023 - 20:50
#permalink

I really enjoy reading and also appreciate your work. commercial landscaping, commercial landscapers, commercial landscapers near me


Автор: James Morgan (не зарегистрирован), дата: 20 марта, 2023 - 20:51
#permalink

This blog is further than my expectations. Nice work guys!!! steam activities for preschoolers, steam learning kits, steam based projects


Автор: James Morgan (не зарегистрирован), дата: 20 марта, 2023 - 20:52
#permalink

This is wonderful and quite informative blog I have learnt so many things from here. life coaches near me, executive career coach, leadership coaching


Автор: Гость (не зарегистрирован), дата: 29 марта, 2023 - 07:26
#permalink

Создание объекта
Создать объект можно двумя способами: tunnel rush
Литеральная нотация - это когда объект описывается фигурными скобками {} и свойства внутри них.
Конструктор объекта - это специальная функция, которая используется для создания объекта.


Автор: 안전놀이터추천 (не зарегистрирован), дата: 29 марта, 2023 - 13:22
#permalink

I finally found what I was looking for! I'm so happy. 안전놀이터추천 Your article is what I've been looking for for a long time. I'm happy to find you like this. Could you visit my website if you have time? I'm sure you'll find a post of interest that you'll find interesting.


Автор: 스포츠톹토사이트 (не зарегистрирован), дата: 19 апреля, 2023 - 12:42
#permalink

What a nice post! I'm so happy to read this. 스포츠톹토사이트 What you wrote was very helpful to me. Thank you. Actually, I run a site similar to you. If you have time, could you visit my site? Please leave your comments after reading what I wrote. If you do so, I will actively reflect your opinion. I think it will be a great help to run my site. Have a good day.


Автор: 바카라사이트 (не зарегистрирован), дата: 27 апреля, 2023 - 13:19
#permalink

That's a really impressive new idea! 바카라사이트 It touched me a lot. I would love to hear your opinion on my site. Please come to the site I run once and leave a comment. Thank you.


Автор: 메이저놀이터 (не зарегистрирован), дата: 2 мая, 2023 - 13:15
#permalink

Your ideas inspired me very much. 메이저놀이터 It's amazing. I want to learn your writing skills. In fact, I also have a website. If you are okay, please visit once and leave your opinion. Thank you.


Автор: chikomo (не зарегистрирован), дата: 10 мая, 2023 - 12:34
#permalink

Your information is really great for me, if I can, please go to moto x3m to relax after stressful working hours. moto x3m bike race game


Автор: chikomo (не зарегистрирован), дата: 10 мая, 2023 - 12:35
#permalink

Your information is really great for me, if I can, please go to moto x3m to relax after stressful working hours. moto x3m bike race game


Автор: 안전놀이터 (не зарегистрирован), дата: 10 мая, 2023 - 12:57
#permalink

Hello, I am one of the most impressed people in your article. 안전놀이터 I'm very curious about how you write such a good article. Are you an expert on this subject? I think so. Thank you again for allowing me to read these posts, and have a nice day today. Thank you.


Автор: 안전놀이터 (не зарегистрирован), дата: 14 мая, 2023 - 12:41
#permalink

Hello, I am one of the most impressed people in your article. 안전놀이터 I'm very curious about how you write such a good article. Are you an expert on this subject? I think so. Thank you again for allowing me to read these posts, and have a nice day today. Thank you.
fg


Автор: 토토사이트 (не зарегистрирован), дата: 17 июня, 2023 - 10:10
#permalink

I am a high school teacher. Your blog helps many students. Students read this blog and solved the problem. I am really happy to have found your blog. 토토사이트


Автор: Гость (не зарегистрирован), дата: 3 июля, 2023 - 12:46
#permalink

Давайте рассмотрим примеры работы с объектами в JavaScript, включая создание объектов, добавление свойств, доступ к свойствам, удаление свойств, расширенное создание объектов и добавление методов blossom word game


Автор: Leyes Violencia Doméstica Nueva Jersey (не зарегистрирован), дата: 13 июля, 2023 - 10:05
#permalink

I appreciate the way you presented both sides of the argument in this post. It allowed me to form a well-rounded opinion.Thank You.Leyes Violencia Doméstica Nueva Jersey


Автор: ufabet (не зарегистрирован), дата: 1 декабря, 2023 - 18:20
#permalink

Great site. A lot of helpful info here. I¡¦m sending it to a few friends ans additionally sharing in delicious. And certainly, thank you for your sweat! ufabet


Автор: UFABET168GO (не зарегистрирован), дата: 17 декабря, 2023 - 10:21
#permalink

ufabet168 ทางเข้า เว็บแทงบอลบริการครบครัน แทงบอลง่าย กำไรงาม


Автор: UFABET168GO (не зарегистрирован), дата: 17 декабря, 2023 - 10:46
#permalink

สมัคร ufabet168 เว็บตรง มั่นคง ปลอดภัย เชื่อถือได้ ถอนเงินได้จริงแน่อน 100% ฝากไม่มีขั้นต่ำ งบน้อยก็เล่นได้ ตอบโจทย์นักเล่นเกมสล็อต


Автор: betflixvip (не зарегистрирован), дата: 17 декабря, 2023 - 17:28
#permalink

You finished certain dependable focuses there. I completed a pursuit regarding the matter and discovered about all people will concur with your blog. betflixvip


Автор: paddlingdeficit (не зарегистрирован), дата: 18 декабря, 2023 - 13:18
#permalink

Excellent website. There is a plethora of useful information available here. I am distributing it to a select group of acquaintances and also sharing it on the social bookmarking website, Delicious. Indeed, I appreciate your effort tunnel rush and hard work!


Автор: pgslot168z (не зарегистрирован), дата: 21 декабря, 2023 - 05:47
#permalink

I just couldn’t depart your site prior to suggesting that I extremely enjoyed the standard information an individual provide for your visitors? Is gonna be back frequently in order to inspect new posts.
pg1688 เว็บ ตรง


Автор: Гость (не зарегистрирован), дата: 2 января, 2024 - 18:55
#permalink

Наслаждайтесь потоковой передачей, как никогда раньше Fmovies. Одним щелчком мыши наслаждайтесь воспроизведением видео в формате Full HD 1080p без рекламы и быстрыми серверами. Регистрация не требуется. Наша библиотека контента — это сокровищница последних выпусков, самой популярной классики, лучших подборок с рейтингом IMDb, а также популярных фильмов и телешоу, которые обновляются ежедневно.


Автор: Гость (не зарегистрирован), дата: 21 июля, 2024 - 04:17
#permalink

In geometry dash Players can design and share their own levels within the game, showcasing their artistic and game design skills.


Автор: frejowski (не зарегистрирован), дата: 15 января, 2024 - 22:47
#permalink

Kancelaria frankowa koncentruje się na trzech głównych obszarach, które mają na celu zabezpieczenie i efektywne egzekwowanie praw naszych klientów: Unieważnienie umowy frankowej, Unieważnienie klauzul abuzywnych (odfrankowanie), Zwrot kosztów sądowych.


Автор: ชิปปิ้ง (не зарегистрирован), дата: 29 апреля, 2024 - 18:19
#permalink

THE ONE CARGO บริษัท ชิปปิ้ง ที่น่าเชื่อถือ และ ไว้ใจได้จะยิ่งทำให้ลูกค้าสะดวก สบายใจในการสั่งซื้อสินค้าจากจีนมากยิ่งขึ้น มีเจ้าหน้าที่ค่อยให้บริการในทุก ๆ ขั้นตอน อีกทั้งยังมีแอพที่ช่วยติดตามสินค้าอย่างใกล้ชิด


Автор: AmeliaHughes (не зарегистрирован), дата: 21 июля, 2024 - 12:45
#permalink

Players begin with a basic planet and work to transform it into a thriving ecosystem. By clicking on various elements, resources are gathered in planet clicker . These resources are vital for upgrading the planet and unlocking new features.


Автор: Гость (не зарегистрирован), дата: 26 июля, 2024 - 02:02
#permalink

Are you tired of hitting walls when trying to access your favorite games? Say goodbye to restrictions and hello to limitless entertainment with unblocked games! Whether you're at school, work, or anywhere with strict internet filters, our collection of unblocked games provides endless opportunities for fun and relaxation.


Автор: Гость (не зарегистрирован), дата: 18 сентября, 2024 - 13:56
#permalink

What I really appreciate about Slope Unblocked is how it encourages players to challenge themselves. Each round feels like a new opportunity to push my limits and improve my skills. I often find myself setting personal goals, like trying to beat my previous high score or see how far I can get without crashing. The game’s design makes it easy to get sucked in; I often lose track of time as I focus on perfecting my technique. The sense of accomplishment when I finally reach a new milestone is incredibly rewarding, making every attempt feel worthwhile!


Автор: Гость (не зарегистрирован), дата: 26 июля, 2024 - 10:11
#permalink

What I learned from your article is more than what I have ever learned. io games


Автор: 2048cupcakes (не зарегистрирован), дата: 2 августа, 2024 - 18:10
#permalink

If you love a sweet twist on classic puzzle games, check out 2048 cupcakes. This delightful variation of the 2048 game combines the fun of merging numbers with adorable cupcakes. It’s a tasty treat for your brain!


Автор: Гость lía (не зарегистрирован), дата: 5 сентября, 2024 - 07:08
#permalink

This essay is excellent and really helpful. I've been silently practicing this, and I'm becoming better at it! Enjoy yourself, work harder fnaf 2 free game, and develop your impressiveness


Автор: Lokata (не зарегистрирован), дата: 6 сентября, 2024 - 13:15
#permalink

Mahjong is a vivid tapestry of history, art, and strategy all rolled into one. The game’s ancient roots are evident in the elaborate designs of each tile, from the dragon symbols to the bamboo patterns. Each session is an immersive journey into the past, where the excitement of the game is enhanced by the beauty and complexity of the tiles. The rich colors and intricate details transform the game board into a vibrant tableau, making every move an opportunity to engage with the game's deep cultural heritage. The thrill of Mahjong is not just in winning but in appreciating the artistry and tradition that each tile represents.


Автор: Udyam Registration (не зарегистрирован), дата: 12 сентября, 2024 - 17:14
#permalink

Apply for udyam registration, MSME registration or udyog aadhar with expert team and get your certificate in an easy manner.


Автор: Udyam Registration (не зарегистрирован), дата: 12 сентября, 2024 - 17:14
#permalink

Apply for udyam registration, MSME registration or udyog aadhar with expert team and get your certificate in an easy manner.


Автор: Aurika Stone (не зарегистрирован), дата: 25 сентября, 2024 - 19:43
#permalink

The objective is simple: click on a large burger to earn points, which are then used to unlock upgrades. Some upgrades increase your clicking power, while others automate the clicking process. The key to mastering whopper clicker lies in balancing these upgrades to maximize your points and improve your overall efficiency as you advance in the game.


Отправить комментарий

Приветствуются комментарии:
  • Полезные.
  • Дополняющие прочитанное.
  • Вопросы по прочитанному. Именно по прочитанному, чтобы ответ на него помог другим разобраться в предмете статьи. Другие вопросы могут быть удалены.
    Для остальных вопросов и обсуждений есть форум.
P.S. Лучшее "спасибо" - не комментарий, как все здорово, а рекомендация или ссылка на статью.
Содержание этого поля является приватным и не предназначено к показу.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Разрешены HTML-таги: <strike> <a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> <u> <i> <b> <pre> <img> <abbr> <blockquote> <h1> <h2> <h3> <h4> <h5> <p> <div> <span> <sub> <sup>
  • Строки и параграфы переносятся автоматически.
  • Текстовые смайлы будут заменены на графические.

Подробнее о форматировании

CAPTCHA
Антиспам
11 + 5 =
Введите результат. Например, для 1+3, введите 4.
 
Текущий раздел
Поиск по сайту
Содержание

Учебник javascript

Основные элементы языка

Сундучок с инструментами

Интерфейсы

Все об AJAX

Оптимизация

Разное

Дерево всех статей

Последние комментарии
Последние темы на форуме
Forum