Mic*_*cah 170 javascript
我正在学习JavaScript,在浏览jQuery库时,我看到:(冒号)被大量使用.这在JavaScript中用于什么?
// Return an array of filtered elements (r)
// and the modified expression string (t)
return { r: r, t: t };
Run Code Online (Sandbox Code Playgroud)
yfe*_*lum 234
var o = {
r: 'some value',
t: 'some other value'
};
Run Code Online (Sandbox Code Playgroud)
在功能上等同于
var o = new Object();
o.r = 'some value';
o.t = 'some other value';
Run Code Online (Sandbox Code Playgroud)
Bre*_*ton 86
而且,冒号可用于标记语句.例如
var i = 100, j = 100;
outerloop:
while(i>0) {
while(j>0) {
j++
if(j>50) {
break outerloop;
}
}
i++
}
Run Code Online (Sandbox Code Playgroud)
Bre*_*ton 66
你们忘记了冒号也用在三元运算符中(虽然我不知道jquery是否将它用于此目的).
三元运算符是if/then语句的表达式(表达式返回值).它的使用方式如下:
var result = (condition) ? (value1) : (value2) ;
Run Code Online (Sandbox Code Playgroud)
三元运算符也可以用于产生副作用,就像if/then一样,但这是非常糟糕的做法.
Dan*_*ert 41
':'基本上是键值对的分隔符.在您的示例中,它是一个Javascript Object Literal表示法.
在javascript中,对象定义为使用冒号分隔属性的标识符及其值,以便您可以拥有以下内容:
return {
Property1 : 125,
Property2 : "something",
Method1 : function() { /* do nothing */ },
array: [5, 3, 6, 7]
};
Run Code Online (Sandbox Code Playgroud)
然后使用它像:
var o = {
property1 : 125,
property2 : "something",
method1 : function() { /* do nothing */ },
array: [5, 3, 6, 7]
};
alert(o.property1); // Will display "125"
Run Code Online (Sandbox Code Playgroud)
其中一个子集也称为JSON(Javascript Object Notation),它在AJAX调用中很有用,因为它紧凑且可以快速解析服务器端语言,Javascript可以轻松地将JSON字符串反序列化为对象.
// The parenthesis '(' & ')' around the object are important here
var o = eval('(' + "{key: \"value\"}" + ')');
Run Code Online (Sandbox Code Playgroud)
如果密钥包含某种特殊字符或空格,您也可以将密钥放在引号内,但我不建议这样做,因为它只会让事情更难处理.
请记住,JavaScript语言中的JavaScript Object Literal Notation与消息传递的JSON标准不同.2之间的主要区别在于函数和构造函数不是JSON标准的一部分,但在JS对象文字中是允许的.
ban*_*ndi 17
它是对象文字语法的一部分.基本格式是:
var obj = { field_name: "field value", other_field: 42 };
Run Code Online (Sandbox Code Playgroud)
然后您可以使用以下方法访问这些值
obj.field_name; // -> "field value"
obj["field_name"]; // -> "field value"
Run Code Online (Sandbox Code Playgroud)
您甚至可以将函数作为值,基本上为您提供对象的方法:
obj['func'] = function(a) { return 5 + a;};
obj.func(4); // -> 9
Run Code Online (Sandbox Code Playgroud)
use*_*627 13
它可用于列出变量中的对象.此外,它在if句子的简写中使用了一点:
var something = {face: 'hello',man: 'hey',go: 'sup'};
Run Code Online (Sandbox Code Playgroud)
并且这样称呼它
alert(something.man);
Run Code Online (Sandbox Code Playgroud)
if句子:
function something() {
(some) ? doathing() : dostuff(); // if some = true doathing();, else dostuff();
}
Run Code Online (Sandbox Code Playgroud)
sch*_*gel 10
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";
Run Code Online (Sandbox Code Playgroud)
如果您使用第三方库,该库返回的值具有您想要在代码中重命名的尴尬/长变量名称,则这非常有用。
这些通常是在JavaScript中使用冒号':'的情况
1-声明和初始化对象
var Car = {model:"2015", color:"blue"}; //car object with model and color properties
Run Code Online (Sandbox Code Playgroud)
2-设置标签(不推荐使用,因为它会导致复杂的控制结构和Spaghetti代码)
List:
while(counter < 50)
{
userInput += userInput;
counter++;
if(userInput > 10000)
{
break List;
}
}
Run Code Online (Sandbox Code Playgroud)
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";
}
Run Code Online (Sandbox Code Playgroud)
4-在三元运算符中
document.getElementById("demo").innerHTML = age>18? "True" : "False";
Run Code Online (Sandbox Code Playgroud)
这是JSON或JavaScript Object Notation.这是描述对象或哈希映射的快速方法.冒号之前的东西是属性名称,冒号之后的东西是它的值.所以在这个例子中,有一个属性"r",其值是变量r中的任何值.同样的t.
我不久前犯的一个愚蠢错误可能会对某些人有所帮助。
请记住,如果您在此类事件中使用“:”,则该值不会改变
var ondrag = (function(event, ui) {
...
nub0x: event.target.offsetLeft + event.target.clientWidth/2;
nub0y = event.target.offsetTop + event.target.clientHeight/2;
...
});
Run Code Online (Sandbox Code Playgroud)
因此“nub0x”将使用发生的第一个事件进行初始化,并且永远不会更改其值。但“nub0y”将在接下来的事件中发生变化。
| 归档时间: |
|
| 查看次数: |
133548 次 |
| 最近记录: |