Javascript中引用类型传递的知识点小结


Posted in Javascript onMarch 06, 2017

JS里面哪些类型是引用类型?

Object类型都是引用类型.(function,array,date,regexp..)

JS哪些类型是值传递?

基本类型都是值传递.值传递就是重新copy一个副本进行传递.

如何把值类型的变量以引用类型的方式进行传递?

通过把基础类型包装之后可以以引用类型传递.

ECMAScript提供了三个特殊的引用类型(基本包装类型): Boolean,String,Number.

引用类型与基本包装类型的区别: 对象的生存期不同.

见代码:

var str = "hello js"; 
var str2 = str.substring(2,5); 


// str2的形成 在JS内部是这样实现的.

var str = new String('hello js');
var str2 = str.substring(2,5);
str = null ;

引用类型的内存分配

如: var o = {name: ‘kobe'};

Javascript中引用类型传递的知识点小结

栈: 保存的是一个指针,指向的是对象在堆上面的内存地址.我们通过指针句柄来操作堆上面的对象.

理解== 与 === 的区别

“===” 严格运算符

严格运算符的运算规则:

1、不同数据类型

如果两个值的类型不同,直接返回false。

2、同一类型的基本数据类型(string,boolean,number)

同一类型的原始类型的值(数值、字符串、布尔值)比较时,值相同就返回true,值不同就返回false。

3、同一类型的复合数据类型

两个复合类型(对象、数组、函数)的数据比较时,不是比较它们的值是否相等,而是比较它们是否指向同一个对象。

console.log( [1] === [1] ) // false

4、undefined和null

undefined 和 null 与自身严格相等。

console.log( null === null ) // true
console.log( undefined === undefined ) // true

“==” 相等运算符

相等运算符在比较相同类型的数据时,与严格相等运算符完全一样。

在比较不同类型的数据时,相等运算符会先将数据进行类型转换,然后再用严格相等运算符比较。类型转换规则如下(以下讨论的是不同类型):

1、都是原始类型的值得情况

原始类型的数据会转换成数值类型再进行比较。

2、对象与原始类型值比较

对象(这里指广义的对象,包括数值和函数)与原始类型的值比较时,对象转化成原始类型的值,再进行比较。

3、undefined和null

undefined和null与其他类型的值比较时,结果都为false,它们互相比较时结果为true

console.log( null == undefined ) // true

4、相等运算符的缺点

相等运算符隐藏的类型转换,会带来一些违反直觉的结果。

console.log( "" == "0" ) // false 
console.log( 0 == "" ) // true
console.log( 0 == "0" ) // true
console.log( false == "false" ) // false
console.log( false == "0" ) // true

还有一个就是涉及undefined的条件判断,undefined与null的条件判断.可能会对你的代码造成印象.

var a = undefined;
if(!a){
 console.log("1"); //1
}

var a = undefined;
if(a === null){
 console.log("1"); //无输出
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript 打印页面代码
Mar 24 Javascript
JavaScript isArray()函数判断对象类型的种种方法
Oct 11 Javascript
让alert不出现弹窗的两种方法
May 18 Javascript
JavaScript中操作Mysql数据库实例
Apr 02 Javascript
jquery实现多屏多图焦点图切换特效的方法
May 04 Javascript
原生JS实现几个常用DOM操作API实例
Jan 19 Javascript
vue+iview写个弹框的示例代码
Dec 05 Javascript
vue移动端实现下拉刷新
Apr 22 Javascript
vue 表单输入格式化中文输入法异常问题
May 30 Javascript
详解vue中axios的使用与封装
Mar 20 Javascript
vue获取时间戳转换为日期格式代码实例
Apr 17 Javascript
vue中watch和computed为什么能监听到数据的改变以及不同之处
Dec 27 Javascript
vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
Mar 06 #Javascript
js正则表达式验证表单【完整版】
Mar 06 #Javascript
Vue.js 2.0 移动端拍照压缩图片上传预览功能
Mar 06 #Javascript
js实现动态显示时间效果
Mar 06 #Javascript
jQuery实现 上升、下降、删除、添加一行代码
Mar 06 #Javascript
Node.js使用NodeMailer发送邮件实例代码
Mar 06 #Javascript
js eval函数使用,js对象和字符串互转实例
Mar 06 #Javascript
You might like
PHP超级全局变量数组小结
2012/10/04 PHP
PHP把空格、换行符、中文逗号等替换成英文逗号的正则表达式
2014/05/04 PHP
PHP+ajax分页实例简析
2015/12/07 PHP
php实现JWT验证的实例教程
2020/11/26 PHP
用JavaScript对JSON进行模式匹配(Part 1-设计)
2010/07/17 Javascript
jquery弹窗插件colorbox绑定动态生成元素的方法
2014/06/20 Javascript
JavaScript中var关键字的使用详解
2015/08/14 Javascript
深入浅析AngularJS中的module(模块)
2016/01/04 Javascript
jQuery事件绑定用法详解(附bind和live的区别)
2016/01/19 Javascript
Bootstrap Metronic完全响应式管理模板之菜单栏学习笔记
2016/07/08 Javascript
老生常谈javascript的类型转换
2016/10/12 Javascript
微信小程序加载更多 点击查看更多
2016/11/29 Javascript
原生js实现吸顶效果
2017/03/13 Javascript
vue-resource + json-server模拟数据的方法
2017/11/02 Javascript
Angular4学习之Angular CLI的安装与使用教程
2018/01/04 Javascript
nodejs中密码加密处理操作详解
2018/03/20 NodeJs
JavaScript实现的九种排序算法
2019/03/04 Javascript
基于iview-admin实现动态路由的示例代码
2019/10/02 Javascript
javascript Canvas动态粒子连线
2020/01/01 Javascript
原理深度解析Vue的响应式更新比React快
2020/04/04 Javascript
Python随手笔记之标准类型内建函数
2015/12/02 Python
python+tkinter编写电脑桌面放大镜程序实例代码
2018/01/16 Python
Python运维自动化之nginx配置文件对比操作示例
2018/08/29 Python
如何在django中添加日志功能
2020/02/06 Python
使用tensorflow进行音乐类型的分类
2020/08/14 Python
python Scrapy框架原理解析
2021/01/04 Python
路易威登和香奈儿手袋:LuxeDH
2017/01/12 全球购物
全球最大的户外用品零售商之一:The House
2018/06/12 全球购物
以设计师精品品质提供快速时尚:Mostata
2019/05/10 全球购物
年度考核自我鉴定
2013/11/09 职场文书
师范生的个人求职信范文
2014/01/04 职场文书
仓库规划计划书
2014/04/28 职场文书
大学班级计划书
2014/04/29 职场文书
刑事上诉状范文
2015/05/22 职场文书
网络舆情信息简报
2015/07/21 职场文书
简单且有用的Python数据分析和机器学习代码
2021/07/02 Python