zoukankan      html  css  js  c++  java
  • Javascript小结(四)----包装对象

    Javascript对象是一个复合值:是属性或者已经命名值的集合。通过 。或者[]来引用属性。当属性值是一个函数的时候,称为方法。


    字符串不是对象,但是有属性?因为主要引用了字符串的属性,Javascript就会将字符串值通过调用new String()的方式来转换成对象。这个对象继承了字符串的方法,处理属性的引用。相应的数字和布尔值也各自有方法:Number()和Boolean()构造函数来创建一个临时的对象。unll和undefined没有包装对象。


    var s="test";
    
    s.len=4;//给s设置一个属性,并且赋值4
    
    var t=s.len;//查询这个属性

    这段代码运行的结果是t=undefined。因为第二个代码创建了一个临时的字符串对象,并给len属性赋值4,但是,当这段代码执行完成的时候,立马就会销毁这个临时的对象(也叫做包装对象)包装对象只是用来区分字符串值和字符串对象,数字和数字对象,布尔值和布尔对象。第三行代码通过给原始的(没有被修改过的)字符串创建一个新的字符串对象,尝试读取len属性,这个属性自然不存在,所以为undefined。


    结论:


    在读取字符串,数字和布尔值的属性值或者方法的时候,表现的像对象一样。但是如果试图给其属性赋值,则会忽略这个操作:修改只会发生在临时对象身上,而这个临时对象并没有继续保留下来。故:字符串,数字和布尔值的属性都是只读的,不能给他们定义新的属性。


    var s='test' ,n=1,b=true;
    
    var S=new String(s);//字符串对象
    
    var N=new Number(n);//数字对象
    
    var B=new Boolean(b);//布尔对象

    S N B常常表现的和s n b一样。但是通过typeof运算符可以看到原始值和其包装对象不同

  • 相关阅读:
    java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0 *&* 解决方法
    一个罕见的MSSQL注入漏洞案例
    工具推荐:ATSCAN,功能强大的Perl脚本扫描器
    突破XSS字符限制执行任意JS代码
    用Nginx分流绕开Github反爬机制
    浅析XSS与XSSI异同
    IE安全系列之——RES Protocol
    跨站请求伪造(CSRF)攻击原理解析:比你所想的更危险
    SQL注入攻击和防御
    SQL 注入,永不过时的黑客技术
  • 原文地址:https://www.cnblogs.com/linewman/p/9918387.html
Copyright © 2011-2022 走看看