dtb
dtb

Reputation: 217313

What does ‘::’ (double colon) do in JavaScript?

The documentation of some JavaScript APIs shows the following snippets as an example of how to invoke some function:

<button type="button" onClick="foo.DoIt(72930)">Click</button>

<button type="button" onClick="foo.DoIt(42342::37438)">Click</button>

:: is obviously used here to allow either one or two arguments to be passed to the function.

What does :: do in JavaScript?

And how does the function know if one or two values were passed? How does it read them?


On closer look, the examples show other weird stuff like

<button type="button" onClick="foo.Bar(72//893)">Click</button>

<button type="button" onClick="foo.Qux(425;1,34::)">Click</button>

At least the // looks just wrong.

So I guess it's not some fancy new syntax that I'm not aware of, but maybe the examples are just missing quotes around a single string argument.

Upvotes: 31

Views: 41136

Answers (8)

Brann
Brann

Reputation: 32376

It was certainly not the case at the time of your question, but right now :: is a valid ES7 operator. It's actually a shortcut for bind.

::foo.bar

is equivalent to

foo.bar.bind(foo)

See an explanation here for examples:

Upvotes: 284

Joel Coehoorn
Joel Coehoorn

Reputation: 415810

:: has nothing to do with the number of parameters. You can do that already in JavaScript with a normal comma:

function SomeFunction(param1, param2) {
   //...
}

SomeFunction('oneParam'); // Perfectly legal

Also, based on Tzury Bar Yochay's answer, are you sure you're not looking at something like the following?

$('this::is all one::parameter'); // jQuery selector

Upvotes: 7

Chris Kooken
Chris Kooken

Reputation: 33880

Perhaps it's a typo, and the whole thing is expected to be in quotes.

Upvotes: 0

Jeff Lewis
Jeff Lewis

Reputation: 1091

It could be using ECMAScript for XML (ECMA-357 standard) which would imply the double quotes are a XPath operator.

See ECMAScript for XML

Upvotes: 1

Xinus
Xinus

Reputation: 30513

It must be a typo for

<button type="button" onClick="foo.DoIt('72930')">Click</button>

<button type="button" onClick="foo.DoIt('42342::37438')">Click</button>

Upvotes: 1

D&#39;Arcy Rittich
D&#39;Arcy Rittich

Reputation: 171421

I am guessing that the parameter list for foo.DoIt() is generated by code, and one the values was empty.

Upvotes: 0

Tzury Bar Yochay
Tzury Bar Yochay

Reputation: 9004

In which example did you see that? So far, JavaScript does not have a double colon operator!

The double colon replaced the single-colon selectors for pseudo-elements in CSS3 to make an explicit distinction between pseudo-classes and pseudo-elements. But that is CSS3, not JavaScript! Not At ALL!

Upvotes: 2

Quentin
Quentin

Reputation: 943579

Nothing. It is a syntax error.

>>> alert(42342::37438)
SyntaxError: missing ) after argument list

Upvotes: 15

Related Questions