一个关于字符串的故事

  • 白小霁
  • 2 Minutes
  • April 11, 2017

字符串(补)

其实,我以前一直都认为语言中「万物皆对象」这一理念,以至于我在「JavaScript」学习中也这样看。
回想理念的起点应该是大一的一次讲座,那是一个Java学习的讲座。可当自己学习前端的过程中,对
「对象」等概念几乎都没有了。今天,突然悟出来一点道理。就是下面这两句话(仅涉及JavaScript中)。

  1. 只有对象才有属性
  2. 字符串不是对象

因为身边的好友多少会有一些「JavaScript」的基础,所以在这里我就不解释什么是「对象」或「字符串」。
此时,回过来看看这两句话,第一句很好理解,因为我们平时就是这样写的。

Paste_Image.png
当时第二句话,就一定有问题了。请你回想10秒。你就会发现,我们经常会写'aaa'.length'aaa'.substring(x,x)….
可能你觉得很平常,但是当你看到下面的显示的时候,我反正之前一直纠结的。

Paste_Image.png
当然还有使用构造函数的方法创建字符串对象(请注意我的措词)。当然这样也不能放弃我们来验证字符串不是对象的理由。因为第一句话
一定是对的。如果是对象就可以做到设置新属性访问属性,如下图:

Paste_Image.png
那我来试试字符串的,如下图:

Paste_Image.png

发现我们只能设置属性,但是不能访问设置过的属性。可是就有这么一个疑问了,为什么可以设置呢?我们的想法是,浏览器在解析到字符串
.的时候,默默的给我们创建了一个值与原来的字符串相同的字符串对象(请多看几遍这句话)。

1
2
3
4
5
var a = 'baiji';
a.name = 'xiaoming' // 'xiaoming'
// 伪代码显示
// temp = new String("baiji");
// a.name ==> temp.name

但是临时对象(temp)返回结果之后,浏览器销毁了其值,所以当我们访问a.name的时候只会得到undefined
这样一来确实解决了为什么字符串使用方法的时候都要用另一个变量接住,而不是跟数组一样的对象改变其本身。

总结

  1. 只有对象才有属性
  2. 字符串不是对象
  3. 「万物皆对象」有待商议

听说这个是「JavaScript Magic」,我上网找到了一篇类似的解释,如果你有更好的解释或者发现自己发邮件给我。


本文章著作权归白小霁所有,转载须说明来源