javascript基本语法总结

一、概括

javascript是浏览器的广泛支持的脚本语言,接收用户事件,处理web文档内容。下文没有提到的基本语法要素基本与c语言相同。

二、词法结构

  2.1、支持unicode。

  2.2、大小写敏感,忽略空白符,和C++兼容的注释。

  2.3、不同行代码之间的分号是可选的。

  2.4、标识符开头可以是$,字母,下划线。

三、基本数据类型

  js是动态语言,数据类型是动态推定的。

  3.1、数字类型

  3.2、字符串,单引号字符串和双引号字符串

  3.3、BOOL类型,true 和 false

  3.4、NULL

  3.5、undefined,变量的类型还没有被确定

四、变量定义

  4.1、变量用var定义

  4.2、变量作用域范围是函数,没有类似与C语言的块级作用域

五、表达式和运算符

  5.1、>> 算术右移,>>> 逻辑右移

  5.2、===,!== 不进行类型转换强类型对象的相等性判断。

六、语句

  6.1、for(var in array){}

  6.2、try{throw;}catch(e){}finnally{}

  6.3、with语句临时改变名称空间。

七、函数和对象

        7.1、函数也是对象,不同之处在于函数有一个隐藏属性,可执行的代码快及其上下文,因为此,函数可以被调用,当函数被调用时产生函数列表属性。       

function myfunc()
{
    var temp=0;
    for(i in arguments) {
        temp+=arguments[i]; //通过arguments,函数的定义就非常灵活了
    }
    
    return temp;
}
alert(myfunc());
alert(myfunc(1,2,3));

for (j in myfunc) {
    alert(j); //函数的属性都是隐藏的
}

        7.2、函数中的this引用,函数根据上下文对其this引用进行动态绑定。

var num=100;

function myfunc()
{
    alert(num);//始终指向全局空间,100
    alert(this.num);
    function inner() {
        alert(this.num);//内部函数的this指向全局空间,100
    }
    inner();
}

obj1={num:99};
obj2={num:98,func:myfunc};

myfunc(); //默认this绑定到全局空间,100
myfunc.call(obj1);//绑定到特定对象,99
obj2.func();//当作为属性调用时绑定到调用对象,98
        7.3、javascript中,没有类的概念,一个对象是从另一个函数对象产生的,可以简单的把函数理解为有构造函数的功能,但是和c++中的构造函数的实现方式有所不同。

当函数被当作构造函数时,this指向如下所示。

function myfunc()
{
    this.age=28;
    this.name="justsong";
}

obj1=new myfunc();
//步骤1、new出obj1
//步骤2、让obj1继承myfunc,也就是原型链接
//步骤3、this指向obj1,并进行初始化操作
alert(obj1.age);
alert(obj1.name);
        7.4、闭包

闭包就是一个内部函数对象,这个对象含有了在被创建时的上下文环境。

function outer() {
    var num=0;
    function inner() {
        num++;
        alert(num);
    }
    
    return inner;
}

bibao1=outer();
bibao1(); //1
bibao1(); //2
bibao1(); //3


  

你可能感兴趣的:(web前端)