Я изучаю JavaScript и, просматривая библиотеку jQuery, вижу, что : (двоеточие) часто используется. Для чего это используется в JavaScript?
// Return an array of filtered elements (r)
// and the modified expression string (t)
return { r: r, t: t };



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


var o = {
r: 'some value',
t: 'some other value'
};
функционально эквивалентен
var o = new Object();
o.r = 'some value';
o.t = 'some other value';
Что делать, если ограждающего объекта нет?
@ FranciscI.B, если бы мне пришлось догадаться, я думаю, что это TypeScript, который является расширенным набором JavaScript. Он объявляет класс с переменной xMin с типом float. Довольно сюрприз, вот что это значит.
Это JSON или объектная нотация JavaScript. Это быстрый способ описания объекта или хэш-карты. Вещь перед двоеточием - это имя свойства, а вещь после двоеточия - его значение. Итак, в этом примере есть свойство «r», значение которого равно значению переменной r. То же для т.
JSON - это только подмножество синтаксиса инициализации объекта JavaScript. '{a: k ()}', где k - функция, не является JSON, но это прекрасный синтаксис инициализации объекта JavaScript.
Чтобы быть педантичным, нет, это не JSON. Это выглядит, как JSON. Это синтаксис литерала объекта, который является родным для JavaScript и может появляться непосредственно внутри кода. С другой стороны, JSON - это формат сериализации / обмена данными. JSON является JSON только тогда, когда он «находится в воздухе», то есть в пути или когда он еще не преобразован в реальный объект.
+1 для Атеса Горала, но обратите внимание, что данный пример даже не смотрю, как JSON: имена должны быть в двойных кавычках, чтобы он был действительным синтаксисом JSON.
Это часть синтаксиса литерала объекта. Базовый формат:
var obj = { field_name: "field value", other_field: 42 };
Затем вы можете получить доступ к этим значениям с помощью:
obj.field_name; // -> "field value"
obj["field_name"]; // -> "field value"
Вы даже можете иметь функции как значения, в основном предоставляя вам методы объекта:
obj['func'] = function(a) { return 5 + a;};
obj.func(4); // -> 9
Отлично, потому что это дало мне термин, по которому я мог искать и получать дополнительную информацию.
':' В основном является разделителем для пар "ключ-значение". В вашем примере это обозначение литерала объекта Javascript.
В javascript объекты определяются двоеточием, разделяющим идентификатор свойства и его значение, поэтому вы можете иметь следующее:
return {
Property1 : 125,
Property2 : "something",
Method1 : function() { /* do nothing */ },
array: [5, 3, 6, 7]
};
а затем используйте его как:
var o = {
property1 : 125,
property2 : "something",
method1 : function() { /* do nothing */ },
array: [5, 3, 6, 7]
};
alert(o.property1); // Will display "125"
Подмножество этого также известно как JSON (Javascript Object Notation), которое полезно в вызовах AJAX, поскольку оно компактно и быстро анализируется на серверных языках, а Javascript может легко десериализовать строку JSON в объект.
// The parenthesis '(' & ')' around the object are important here
var o = eval('(' + "{key: \"value\"}" + ')');
Вы также можете поместить ключ в кавычки, если он содержит какой-то специальный символ или пробелы, но я бы не рекомендовал это, потому что это просто усложняет работу.
Имейте в виду, что Обозначение объекта JavaScript Буквальный в языке JavaScript отличается от стандарта JSON для передачи сообщений. Основное различие между этими двумя состоит в том, что функции и конструкторы не являются частью Стандарт JSON, но разрешены в литералах объектов JS.
Когда я прочитал ваш ответ, я подумал, что проголосую за него, но потом вы сказали, что «Он также известен как JSON». Объектные литералы и JSON определенно являются нет одним и тем же, действительно, ваши примеры до того, как вы упомянули JSON, недействительны JSON.
@nnnnnn Разница между этими двумя очень тонкая, но, тем не менее, важная. Я обновил свой ответ, чтобы быть более конкретным по этому поводу.
Вижу обновление. Хороший. Обратите внимание, что в JSON требует имена ключей заключены в кавычки.
Почему вы должны упомянуть все это дважды? Когда вы сказали "а потом используйте это как"
Вы, ребята, забываете, что двоеточие также используется в тернарном операторе (хотя я не знаю, использует ли его jquery для этой цели).
тернарный оператор - это форма выражения (выражения возвращают значение) оператора if / then. он используется так:
var result = (condition) ? (value1) : (value2) ;
Тернарный оператор также может использоваться для создания побочных эффектов, как если бы / тогда, но это в корне плохая практика.
AKA «тернарный оператор». Обратите внимание, что OP строго спрашивает о буквальном регистре объекта. Если мы пойдем даже дальше того, что запрашивает OP, двоеточие также используется в ярлыках.
да, я действительно это имел в виду. На самом деле, я должен просто держаться подальше от Интернета, если я собираюсь обходить стороной, грубо неверно идентифицируя подобные концепции программирования.
Было бы здорово увидеть, как он используется для ярлыков и всего остального, поэтому использование никогда не сбивается с толку @AtesGoral, потому что я сейчас все еще гуглию их.
Может быть, было бы проще перечислить то, для чего: не используется в Javascript.
Кроме того, для обозначения оператора можно использовать двоеточие. Например
var i = 100, j = 100;
outerloop:
while(i>0) {
while(j>0) {
j++
if (j>50) {
break outerloop;
}
}
i++
}
Добро пожаловать в Spaghetti Code :)
Goto нельзя замаскировать: вы просто прерываете goto; и вы его нашли! ;)
Справочная страница MDN для ярлыка JS: developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…
да, вот почему a => {b: 2} не будет бросать и возвращать undefined
Не забываем оператор switch, в котором двоеточие ставится после каждого «case».
Его можно использовать для перечисления объектов в переменной. Кроме того, он немного используется в сокращении предложения if:
var something = {face: 'hello',man: 'hey',go: 'sup'};
И называя это так
alert(something.man);
Также предложение if:
function something() {
(some) ? doathing() : dostuff(); // if some = true doathing();, else dostuff();
}
Обычно это сценарии, в которых двоеточие ':' используется в JavaScript.
1- Объявление и инициализация объекта
var Car = {model:"2015", color:"blue"}; //car object with model and color properties
2- Установка метки (не рекомендуется, так как это приводит к сложной структуре управления и коду спагетти)
List:
while(counter < 50)
{
userInput += userInput;
counter++;
if (userInput > 10000)
{
break List;
}
}
3- В заявлении Switch
switch (new Date().getDay()) {
case 6:
text = "Today is Saturday";
break;
case 0:
text = "Today is Sunday";
break;
default:
text = "Looking forward to the Weekend";
}
4- Тернарный оператор
document.getElementById("demo").innerHTML = age>18? "True" : "False";
Одно двоеточие также может использоваться для оценки короткого замыкания вместо ||. Пример: var a = false, b = a || 'Default value'; эквивалентен var a = false, b = a : 'Default value';
Одна глупая ошибка, которую я совершил некоторое время назад, может помочь некоторым людям.
Имейте в виду, что если вы используете ":" в подобном событии, значение не изменится.
var ondrag = (function(event, ui) {
...
nub0x: event.target.offsetLeft + event.target.clientWidth/2;
nub0y = event.target.offsetTop + event.target.clientHeight/2;
...
});
Таким образом, «nub0x» инициализируется первым происходящим событием и никогда не изменит своего значения. Но "nub0y" изменится в следующих ивентах.
Я наткнулся на это, и, к сожалению, на самом деле здесь происходит то, что вы используете ярлык перед своим утверждением. Присваивания не производится, но оператор event.target.offsetLeft + event.target.clientWidth/2; запускается каждый раз, когда вызывается ваш метод ondrag, но никогда не присваивает значение nub0x.
На самом деле это используется в качестве оценки, и : рассматривается как ||. Следовательно, event.target.offsetLeft + event.target.clientWidth/2; будет срабатывать только каждый раз, если nub0x приравнивается к false.
Еще одно использование двоеточия в JavaScript - переименование переменной, а именно:
const person = {
nickNameThatIUseOnStackOverflow: "schlingel",
age: 30,
firstName: "John"
};
let { nickNameThatIUseOnStackOverflow: nick } = person; // I take nickNameThatIUseOnStackOverflow but want to refer it as "nick" from now on.
nick = "schling";
Это полезно, если вы используете стороннюю библиотеку, которая возвращает значения с неудобными / длинными именами переменных, которые вы хотите переименовать в своем коде.
Так похож на синтаксис инициализатора объекта C#. Спасибо!