zoukankan      html  css  js  c++  java
  • String Primitive和String Object

    网上看到下面这段代码,很有意思。

    String.prototype.cut = function (len) {
      return this.length > len ? this.substring(0, len) + '...' : this;
    };
    
    var obj = ["Superman", "Batman", "Iron Man"];
    console.log(typeof obj[1].cut(6));
    console.log(obj[1].cut(6));
     

    这段代码很简单,判断字符串的长度,如果大于给定长度(L)输出,输出字符串前L位加上“…”,否则输出字符串本身。

    那么,上面的代码是不是和我们期待的一样输出下面的内容呢?

    "String"
    "Batman"

    答案是否定的,实际的输出其实是:

    "object"
    <String Object>

    这其实是因为String对象(String Object)和String基本类型(String Primitive)的不同导致的。字符串在JavaScript中有两种存在形式

    new String('object');// String Object
    'primitive';// String Primitive

    String的所有实用方法其实都是在String对象的prototype上,String基本类型是没有这些方法的。

    因此当执行'primitive'.slice(0)时,JavaScript会自动将基本类型包装成对应的对象,调用对象上的方法,完成之后自动将对象销毁。因此,最上面的cut函数中this其实已经不是String Primitive而是String Object,当我们直接返回this,返回值其实是”Batman”的String Object,所以typeof返回”object”。

    所以,这个cut函数正确写法应该用String转换函数将Object转为Primitive。

    String.prototype.cut = function (len) {
      return this.length > len ? this.substring(0, len) + '...' : String(this);
    };
  • 相关阅读:
    阿里云:面向5G时代的物联网无线连接服务
    走近科学,探究阿里闲鱼团队通过数据提升Flutter体验的真相
    Redis 5.0新功能介绍
    阿里云发布 Redis 5.0 缓存服务:全新 Stream 数据类型带来不一样缓存体验
    荣获“5G MEC优秀商用案例奖”,阿里云边缘计算发力新零售
    阿里云亮相2019联通合作伙伴大会,边缘计算等3款云产品助力5G时代产业数字化转型
    noip2014 寻找道路
    noip2014 无线网络发射器选址
    noip2014 联合权值
    noip2013 华容道
  • 原文地址:https://www.cnblogs.com/betarabbit/p/2753190.html
Copyright © 2011-2022 走看看