JavaScript中的Primitive对象封装介绍


Posted in Javascript onDecember 31, 2014

JavaScript中,string、number、boolean均为primitive基本类型,也即字符串、数值、布尔值并不是以对象的形式而存在的。不过,由于需要对这三种primitive类型值进行操作,因此JavaScript会自动封装这三种类型的值,使其作为对象而拥有属性与方法。以string为例,这种封装过程如下:

1.当JavaScript遇到对string值进行属性访问或者方法调用时,会调用new String(字符串值)自动将该string封装成一个String对象。
2.JavaScript会访问这个新创建的对象的属性或者方法,并返回相应的结果。
3.属性访问或者方法调用结束后,JavaScript将立即销毁这个新创建的对象。

以下面的代码为例,对JavaScript自动创建的String对象进行属性写入操作没有任何意义,因为这个创建出来的对象在写入语句结束后就不复存在了:

var s = "test";

s.length = 9;

console.log(s.length);//still 4

s.newVariable = 9;

console.log(s.newVariable);//undefined

console.log(s === "test");//true

值得注意的是,上述代码中的s变量所表示的永远是primitive的字符串,JavaScript所自动创建的字符串对象存在于执行s.length或者s.newVariable操作的过程中。这可以从以上实验的最后一行代码中得到验证。

除了对Primitive值进行自动封装,开发人员也可以选择手动进行相应的过程。与自动封装不同的是,手动封装所得到的对象并不会被立即销毁,因此针对手动封装的对象所采取的属性写入操作是有意义的:

var t = new String("test");

t.length = 9;

console.log(t.length);//still 4, as length attribute is read only

t.newVariable = 9;

console.log(t.newVariable);//9
console.log(t == "test");//true

console.log(t === "test");//false
Javascript 相关文章推荐
jQuery的deferred对象使用详解
Aug 20 Javascript
javascript椭圆旋转相册实现代码
Jan 16 Javascript
jquery创建一个新的节点对象(自定义结构/内容)的好方法
Jan 21 Javascript
javascript格式化日期时间方法汇总
Jun 19 Javascript
js弹出对话框方式小结
Nov 17 Javascript
JavaScript基础篇(6)之函数表达式闭包
Dec 11 Javascript
JavaScript中 ES6 generator数据类型详解
Aug 11 Javascript
BootStrap 模态框实现刷新网页并关闭功能
Jan 04 Javascript
用纯Node.JS弹出Windows系统消息提示框实例(MessageBox)
May 17 Javascript
JS加密插件CryptoJS实现的Base64加密示例
Aug 16 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
Feb 18 Javascript
原生JS实现多条件筛选
Aug 19 Javascript
JavaScript中的值类型转换介绍
Dec 31 #Javascript
javascript实现滑动解锁功能
Dec 31 #Javascript
JavaScript中number转换成string介绍
Dec 31 #Javascript
JavaScript中string转换成number介绍
Dec 31 #Javascript
JavaScript中的object转换函数toString()与valueOf()介绍
Dec 31 #Javascript
JavaScript中的object转换成number或string规则介绍
Dec 31 #Javascript
javascript 事件处理示例分享
Dec 31 #Javascript
You might like
用php+javascript实现二级级联菜单的制作
2008/05/06 PHP
防止用户利用PHP代码DOS造成用光网络带宽
2011/03/01 PHP
PhpDocumentor 2安装以及生成API文档的方法
2014/05/21 PHP
基于CakePHP实现的简单博客系统实例
2015/06/28 PHP
Jquery选择器 $实现原理
2009/12/02 Javascript
DIV外区域Click后关闭DIV的实现代码
2011/12/21 Javascript
jquery重复提交请求的原因浅析
2014/05/23 Javascript
js清空表单数据的两种方式(遍历+reset)
2014/07/18 Javascript
jquery获得同源iframe内body下标签的值的方法
2014/09/25 Javascript
常用的js验证和数据处理总结
2016/08/02 Javascript
微信小程序实现验证码获取倒计时效果
2018/02/08 Javascript
vue webpack打包优化操作技巧
2018/02/22 Javascript
解决layui上传文件提示上传异常,实际文件已经上传成功的问题
2018/08/19 Javascript
通过npm或yarn自动生成vue组件的方法示例
2019/02/12 Javascript
redux.js详解及基本使用
2019/05/24 Javascript
详解Vue3.0 + TypeScript + Vite初体验
2021/02/22 Vue.js
python小技巧之批量抓取美女图片
2014/06/06 Python
python实现的简单文本类游戏实例
2015/04/28 Python
python动态性强类型用法实例
2015/05/09 Python
Python脚本获取操作系统版本信息
2016/12/17 Python
[原创]Python入门教程4. 元组基本操作
2018/10/31 Python
python实现对任意大小图片均匀切割的示例
2018/12/05 Python
Python Matplotlib库安装与基本作图示例
2019/01/09 Python
python assert的用处示例详解
2019/04/01 Python
python 字典item与iteritems的区别详解
2020/04/25 Python
详解Python高阶函数
2020/08/15 Python
CSS3 实现童年的纸飞机
2019/05/05 HTML / CSS
斯德哥尔摩通票:Stockholm Pass
2018/01/09 全球购物
纽约手袋品牌:KARA
2018/03/18 全球购物
什么是URL
2015/12/13 面试题
酒店管理专业学生求职信
2013/09/27 职场文书
迎新晚会策划方案
2014/06/13 职场文书
先进集体事迹材料范文
2014/12/25 职场文书
2019行政前台转正申请书范文3篇
2019/08/15 职场文书
《家庭教育》读后感3篇
2019/12/18 职场文书
世界各国短波电台对东亚播送时间频率表(SW)
2021/06/28 无线电