JavaScript的内置对象之Global对象

内置对象的定义是:

  由 javaScript 实现提供的、不用自己创建,这些对象在 ECMAScript 程序执行之前就已经存在了。

  意思就是说,开发人员不必显示地实例化内置对象;因为它们已经实例化了。

  JavaScript只定义了两个内置对象:Global和 Math


一、Global(全局)对象:

  javacript 中一个特别的对象,因为这个对象是不存在的。在JavaScript中不属于任何其他对象的属性和方法,都属于它的属性和方法。

  所以,事实上,并不存在全局变量和全局函数;所有在全局作用域定义的变量和函数,都是 Global 对象的属性和方法。

  因为 JavaScript没有定义怎么调用 Global 对象,所以,Global.属性或者 Global.方法()都是无效的。(Web 浏览器将 Global 作为 window 对象的一部分加以实现)

    var box = 100;
    //alert(Global.box);//会报错
    alert(window.box);  //可以使用window来调用

 

 

 

 

二、Global 对象有一些内置的属性和方法:

  1.URI 编码方法:

    URI 编码可以对链接进行编码,以便发送给浏览器。它们采用特殊的 UTF-8 编码替换所有无效字符,从而让浏览器能够接受和理解。

    不会对本身属于 URI 的特殊字符进行编码,例如冒号、正斜杠、问号和#号

    encodeURI()

  var box = ‘//Lee 李‘;
    alert(encodeURI(box)); //只编码了中文     结果是这样//Lee%20%E6%9D%8E

    encodeURIComponent()则会对它发现的任何非标准字符进行编码

   var box = ‘//Lee 李‘;
     alert(encodeURIComponent(box)); //特殊字符和中文编码了    结果是这样%2F%2FLee%20%E6%9D%8E

    因为 encodeURIComponent()编码比 encodeURI()编码来的更加彻底,一般来说encodeURIComponent()使用频率要高一些。

 

  2.URI解码方法:

    使用了 URI 编码过后,还可以进行解码。

     decodeURI()来进行解码

  var box = ‘//Lee 李‘;
    box1 = encodeURI(box); //编码
    alert(box1);
    alert(decodeURI(box1));//解码

    decodeURIComponent()来进行解码

    var box2 = //Lee 李;
    box2 = encodeURIComponent(box); //编码
    alert(decodeURIComponent(box2)); //解码

 

 

 

  3.eval()方法:

    主要担当一个字符串解析器的作用,他只接受一个参数,而这个参数就是要执行的 JavaScript 代码的字符串。(即可以解析javascript代码)

    eval(‘var box = 100‘);     //解析了字符串代码
    alert(box);                //100
    eval(‘alert(100)‘); //同上
    
    
    eval(‘function box() {return 123}‘); //函数也可以
    alert(box());

    eval()方法的功能非常强大,但也非常危险。因此使用的时候必须极为谨慎。特别是在用户输入数据的情况下,非常有可能导致程序的安全性,比如代码注入等等。

 

 

  4.parseInt()方法:返回由字符串转换得到的整数

  var str = "123";
    //从头开始解析,直到不能被解析为止
    document.write(parseInt(str)+"<br />");
    document.write(parseInt("100")+"<br />");
    document.write(parseInt("100abc")+"<br />");
    document.write(parseInt("abc100")+"<br />");
    document.write(parseInt("100abc0")+"<br />");
    
    //将第一个参数按第二个参数转换,第二个参数是进制数,如2进制8进制16进制
    document.write(parseInt("100",2)+"<br />");

   parseFloat()方法:和parseInt类似

 

 

  5.isNaN方法:

    返回一个 Boolean 值,指明提供的值是否是保留值 NaN (不是数字)。 

    如果值是 NaN, 那么 isNaN 函数返回 true ,否则返回 false

    使用这个函数的典型情况是检查 parseIntparseFloat 方法的返回值。 

  alert(isNaN(100));
    alert(isNaN("jaav"));   //true
    alert(isNaN(NaN));
    alert(isNaN(parseInt("123lee")));//parseInt("123lee")的结果是123,所以isNaN(123)为false
    alert(isNaN(parseInt("lee123")));//parseInt("lee123")的结果是NaN,所以isNaN(NaN)为true

 

 

  6.Global 对象属性:

    Global 对象包含了一些属性:undefined、NaN、Object、Array、Function 等等。

    alert(Array); //返回构造函数
    alert(undefined);
    alert(Object);

 

 

  7.window 对象:

    Global 没有办法直接访问,而 Web 浏览器可以使用 window 对象来实现一全局访问。

alert(window.Array); //返回构造函数

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。