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);
    };
  • 相关阅读:
    display的几种常用取值
    css五种定位方式介绍
    单行文字超过某个宽度时,显示省略号
    点击鼠标右键弹出错误提示:CrashHandler initialization error
    基于jquery 的find()函数和children()函数的区别
    跨域问题,前端主动向后台发送cookie
    Boolean()值为false的五个特殊值
    如何把select默认的小三角替换成自己的图片
    如何将网页的title前面的图标替换成自己的图标
    C#阿里云 移动推送 接入
  • 原文地址:https://www.cnblogs.com/betarabbit/p/2753190.html
Copyright © 2011-2022 走看看