js 语法和其他

2019-08-24  本文已影响0人  Super曲江龙Kimi

js语句

所有的js语句其实都会返回结果

在调试工具中执行 var a = 12 会返回undefined ,表示声明变量会返回undefined

表达式的副作用

函数执行的时候,有可能会改变全局变量。

function boo() {
    a = a + 1
}
var a =  1;
boo(); // a被改变

a++表示先赋值再++。 就是用括号扩起来也没有用。想让他++完之后再赋值。需要使用逗号表达式

var a = 42;
a = a++; // 42
a = (a++) //42
a = (a++, a) // 43 

在连续赋值时要注意,如果b没有声明则会创建一个全局变量

var a = b =42 ; 会创建一个全局变量 严格模式报错

也可以利用赋值语句的副作用。先执行再赋值。接着判断

可以利用赋值语句
function vowels(str) {
    var matches;    
    if(str && (matches = str.match(/[aeiou]/g))) {
        // 先判断 如果成功将值赋值给matches 失败返回null不进判断
        return matches;
    }
}
vowels("hello world")

大括号

var a = {
    foo: bar()
}

去掉var a =不会报错

{
    foo: bar()
}
// 因为{}只是I个普通的代码块。

而foo:bar()不会报错的原因是因为foo:被当成了标签, js的标签语法用来break和continue

function foo() {
    bar: {
        console.log('hello');
    }
    break bar;
    console.log(666)
}
foo() // hello

else if

js中本身是没有else if的 是因为if else后面可以省略大括号

if () {
    //
} else {
    if () {
        // 
    } else {
        
    }
}

可以简写为

if() {
}
else if () {
}
else {
}

switch

switch中是===判断 如果想用==

var a = '42';
switch(true) {
    case a == 10;
        console.log(1);
        break;
    case a == 42;
        console.log(2);
        break;
    default;
}
上一篇 下一篇

猜你喜欢

热点阅读