首页 >> js开发 >> js代码JavaScript装箱及拆箱boxing及unBoxing用法解析
js代码JavaScript装箱及拆箱boxing及unBoxing用法解析
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
首先我们来看看这段代码
var s1 = "abc";
var s2 = s1.indexOf("a")
var s1 = "abc";
var s2 = s1.indexOf("a")
s1 是个 string 啊,怎么会有 indexOf() 方法呢?这里就涉及到了 JavaScript 中的装箱与拆箱的概念了装箱:把基本数据类型转化为对应的引用数据类型的操作在《javascript高级程序设计》中有这样一句话:每当读取一个基本类型的时候,后台就会创建一个对应的基本包装类型对象,从而让我们能够调用一些方法来操作这些数据。还是拿最开始的例子
var s1 = "abc";
var s2 = s1.indexOf("a")
var s1 = "abc";
var s2 = s1.indexOf("a")
变量s1是一个基本类型值,它不是对象,它不应该有方法。但是js内部为我们完成了一系列处理(即装箱),使得它能够调用方法,实现的机制如下:(1)创建String类型的一个实例;(2)在实例上调用指定的方法;(3)销毁这个实例;下面来看看代码实现:
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
这样就完成装箱,我们也就能在s1上调用方法了拆箱:将引用类型对象转换为对应的值类型对象拆箱:将引用类型对象转换为对应的值类型对象它是通过引用类型的valueOf()或者toString()方法来实现的。如果是自定义的对象,你也可以自定义它的valueOf()/tostring()方法,实现对这个对象的拆箱。
var objNum = new Number(123);
var objStr =new String("123");
console.log( typeof objNum ); //object
console.log( typeof objStr ); //object
console.log( typeof objNum.valueOf() ); //number
console.log( typeof objStr.valueOf() ); //string
console.log( typeof objNum.toString() ); // string
console.log( typeof objStr.toString() ); // string
var objNum = new Number(123);
var objStr =new String("123");
console.log( typeof objNum ); //object
console.log( typeof objStr ); //object
console.log( typeof objNum.valueOf() ); //number
console.log( typeof objStr.valueOf() ); //string
console.log( typeof objNum.toString() ); // string
console.log( typeof objStr.toString() ); // string以上就是本文的全部内容,希望对大家的学习有所帮助。
var s1 = "abc";
var s2 = s1.indexOf("a")
var s1 = "abc";
var s2 = s1.indexOf("a")
s1 是个 string 啊,怎么会有 indexOf() 方法呢?这里就涉及到了 JavaScript 中的装箱与拆箱的概念了装箱:把基本数据类型转化为对应的引用数据类型的操作在《javascript高级程序设计》中有这样一句话:每当读取一个基本类型的时候,后台就会创建一个对应的基本包装类型对象,从而让我们能够调用一些方法来操作这些数据。还是拿最开始的例子
var s1 = "abc";
var s2 = s1.indexOf("a")
var s1 = "abc";
var s2 = s1.indexOf("a")
变量s1是一个基本类型值,它不是对象,它不应该有方法。但是js内部为我们完成了一系列处理(即装箱),使得它能够调用方法,实现的机制如下:(1)创建String类型的一个实例;(2)在实例上调用指定的方法;(3)销毁这个实例;下面来看看代码实现:
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
这样就完成装箱,我们也就能在s1上调用方法了拆箱:将引用类型对象转换为对应的值类型对象拆箱:将引用类型对象转换为对应的值类型对象它是通过引用类型的valueOf()或者toString()方法来实现的。如果是自定义的对象,你也可以自定义它的valueOf()/tostring()方法,实现对这个对象的拆箱。
var objNum = new Number(123);
var objStr =new String("123");
console.log( typeof objNum ); //object
console.log( typeof objStr ); //object
console.log( typeof objNum.valueOf() ); //number
console.log( typeof objStr.valueOf() ); //string
console.log( typeof objNum.toString() ); // string
console.log( typeof objStr.toString() ); // string
var objNum = new Number(123);
var objStr =new String("123");
console.log( typeof objNum ); //object
console.log( typeof objStr ); //object
console.log( typeof objNum.valueOf() ); //number
console.log( typeof objStr.valueOf() ); //string
console.log( typeof objNum.toString() ); // string
console.log( typeof objStr.toString() ); // string以上就是本文的全部内容,希望对大家的学习有所帮助。
相关文章:
- jsvue项目使用$router.go(-1)返回时刷新原来的界面操作js大全
- js解决VUE mounted 钩子函数执行时 img 未加载导致页面布局的问题js大全
- js解决vue页面渲染但dom没渲染的操作js大全
- js谈一谈vue请求数据放在created好还是mounted里好js大全
- js解决vue的router组件component在import时不能使用变量问题js大全
- js在vue中使用防抖函数组件操作js大全
- jsVue中的this.$options.data()和this.$data用法说明js大全
- jsElement Breadcrumb 面包屑的使用方法js大全
- js解决vue动态路由异步加载import组件,加载不到module的问题js大全
- jsAngular利用HTTP POST下载流文件的步骤记录js大全