Что делает «:» (двоеточие) в JavaScript? - PullRequest
164 голосов
/ 07 января 2009

Я изучаю JavaScript и, просматривая библиотеку jQuery, вижу, что : (двоеточие) часто используется. Для чего это используется в JavaScript?

// Return an array of filtered elements (r)
// and the modified expression string (t)
   return { r: r, t: t };

Ответы [ 11 ]

226 голосов
/ 07 января 2009
var o = {
    r: 'some value',
    t: 'some other value'
};

функционально эквивалентно

var o = new Object();
o.r = 'some value';
o.t = 'some other value';
82 голосов
/ 07 января 2009

Кроме того, двоеточие можно использовать для обозначения оператора. например

var i = 100, j = 100;
outerloop:
while(i>0) {
  while(j>0) {
   j++

   if(j>50) {
     break outerloop;
   }
  }
i++

}
66 голосов
/ 07 января 2009

Вы, ребята, забыли, что двоеточие также используется в троичном операторе (хотя я не знаю, использует ли jquery для этой цели).

Тернарный оператор - это форма выражения (выражения возвращают значение) оператора if / then. это используется так:

var result = (condition) ? (value1) : (value2) ;

Троичный оператор также может быть использован для создания побочных эффектов, как если бы / то, но это очень плохая практика.

41 голосов
/ 07 января 2009

':' - это в основном разделитель для пар ключ-значение. В вашем примере это нотация Javascript Object Literal.

В 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), которая полезна в вызовах AJAX, потому что она компактна и быстра для анализа на серверных языках, и Javascript может легко десериализовать строку JSON в объект.

// The parenthesis '(' & ')' around the object are important here
var o = eval('(' + "{key: \"value\"}" + ')');

Вы также можете поместить ключ в кавычки, если он содержит какие-то специальные символы или пробелы, но я бы не советовал, потому что это только усложняет работу с ним.

Имейте в виду, что Объект JavaScript Литерал Обозначение на языке JavaScript отличается от стандарта JSON для передачи сообщений. Основное различие между ними состоит в том, что функции и конструкторы не являются частью стандарта JSON , но допускаются в литералах объекта JS.

17 голосов
/ 07 января 2009

Это часть литерального синтаксиса объекта. Основной формат:

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
13 голосов
/ 08 июня 2012

Может использоваться для перечисления объектов в переменной. Кроме того, он используется немного в сокращенном предложении if:

var something = {face: 'hello',man: 'hey',go: 'sup'};

И называя это так

alert(something.man);

Также предложение if:

function something() {  
  (some) ? doathing() : dostuff(); // if some = true doathing();, else dostuff();
}
10 голосов
/ 07 июня 2011

Давайте не забудем инструкцию switch, где двоеточие используется после каждого «case».

8 голосов
/ 08 апреля 2016

Обычно это сценарии, в которых двоеточие ':' используется в 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- In Switch Statement

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";
7 голосов
/ 07 января 2009

Это JSON, или JavaScript Object Notation. Это быстрый способ описания объекта или хэш-карты. Вещи перед двоеточием - это имя свойства, а вещи после двоеточия - это его значение. Итак, в этом примере есть свойство «r», значение которого равно значению переменной r. То же самое для т.

3 голосов
/ 09 июня 2016

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

Имейте в виду, что если вы используете «:» в таком событии, значение не изменится

var ondrag = (function(event, ui) {
            ...

            nub0x: event.target.offsetLeft + event.target.clientWidth/2;
            nub0y = event.target.offsetTop + event.target.clientHeight/2;

            ...
        });

Таким образом, «nub0x» инициализируется первым случившимся событием и никогда не изменит своего значения. Но «nub0y» изменится во время следующих событий.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...