首页 > web前端 > js教程 > 正文

JavaScript中原始值是什么?JavaScript中原始值的详解

云罗郡主
发布: 2018-11-23 15:52:53
转载
4040人浏览过

本篇文章给大家带来的内容是关于javascript中原始值是什么?javascript中原始值的详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

原始值:

概念:原始类型的值就是原始值,即原始值有string,、number、boolean、null和undefined五种。

valueOf() 和 toString() 方法的使用:

null和undefined没有valueOf和toString方法,调用时报错。

立即学习Java免费学习笔记(深入)”;

默认情况下调用的是valueOf方法:

每个JavaScript对象的 valueOf 方法定义不同:

微信截图_20181123154924.png

例如:

// 函数:
<script> 
  var f = function () {}
  console.log(f) // ƒ () {}
  console.log(f.toString()) // function () {}
  console.log(f.valueOf()) // f () {}
</script>
// 对象
<script> 
  var obj = {a: 1, b: 'ss'}
  console.log(obj) // {a: 1, b: "ss"}
  console.log(obj.toString()) // [object Object]
  console.log(obj.valueOf()) // {a: 1, b: "ss"}
</script>
登录后复制

(1)调用对象的valueOf方法,如果返回值是原始值直接返回,否则返回对象本身。

(2)对于数组,如果不重写其toString()方法,其默认实现就是调用数组的 join()方法返回值作为toString()的返回值。

例1:

[1,2,3].toString()  // '1,2,3'
var str = new String("11")
console.log(str) //String {"11"}
console.log(str.valueOf()) // 11 (typeof返回string)
console.log(str.toString()) // 11 (typeof返回string)
登录后复制

str.valueOf()的返回值为11的原因:

此处的valueOf方法调用的是String原型上的valueOf方法,而非Object对象原型上的valueOf方法,原型链结构中String.prototype在Object.prototype之前,而String.prototype.valueOf方法返回的是一个字符串,故返回值为11。

例2:

<script>
var obj = new Object({a: 1})
console.log(obj) // {a: 1}
console.log(obj.valueOf()) // {a: 1}
console.log(obj.toString()) // [object Object]
console.log(obj + 1) // [object Object]1
</script>
登录后复制

原因:使用对象进行运算时,首先调用的是valueOf方法,此时valueOf的返回值仍旧是对象,因此会再调用toString方法进行运算,故返回值时[object Object]1。

判断一个值的具体类型:

使用Object.prototype.toString()。call(val)

返回值有:

String | Number | Boolean | Null | Undefined | Function | Array | Object | RegExp | Date | Error | Arguments

以上就是对JavaScript中原始值是什么?JavaScript中原始值的详解的全部介绍,如果您想了解更多有关JavaScript教程,请关注PHP中文网。

以上就是JavaScript中原始值是什么?JavaScript中原始值的详解的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:博客园网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号