js对象引用、基本类型、引用类型
2018-02-12 23:29
471 查看
基本类型<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
/*var a = 5;
var b = a;
b += 3;
alert(b); //8
alert(a); //5
*/
//对象和函数都是引用的关系
/*var a = [1,2,3];
var b = a;
b.push(4);
alert(b); //1,2,3,4
alert(a); //1,2,3,4*/
var a = [1,2,3];
var b = a;
b = [1,2,3,4];
alert(b); //1,2,3,4
alert(a); //1,2,3
</script>
</head>
<body>
</body>
</html>浅拷贝<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
/*var obj = {
a : 10
};
var obj2 = obj;
obj2.a = 20;
alert(obj.a); //20*/
var obj = {
a : 10
};
function copy(obj){ //浅拷贝
var newObj = {};
for(var attr in obj){
newObj[attr] = obj[attr];
}
return newObj;
}
var obj2 = copy(obj);
obj2.a = 20;
alert(obj.a); //10
</script>
</head>
<body>
</body>
</html>
深拷贝<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
var obj = {
a : { b : 10 }
};
/*function copy(obj){ //浅拷贝
var newObj = {};
for(var attr in obj){
newObj[attr] = obj[attr];
}
return newObj;
}*/
function deepCopy(obj){ //深拷贝
if(typeof obj != 'object'){
console.trace();
return obj;
}
var newObj = {};
for(var attr in obj){
newObj[attr] = deepCopy(obj[attr]);
}
return newObj;
}
var obj2 = deepCopy(obj);
obj2.a.b = 20;
alert(obj.a.b); //10
</script>
</head>
<body>
</body>
</html>
递归<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
//递归:
//1.函数调用函数自身,执行递的动作
//2.最后一次判断一个终止条件,可以执行归的动作
function test(n){
if(n==1){
console.trace();
return 1;
}
return n*test(n-1);
}
alert(test(4));
</script>
</head>
<body>
</body>
</html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
/*var a = 5;
var b = a;
b += 3;
alert(b); //8
alert(a); //5
*/
//对象和函数都是引用的关系
/*var a = [1,2,3];
var b = a;
b.push(4);
alert(b); //1,2,3,4
alert(a); //1,2,3,4*/
var a = [1,2,3];
var b = a;
b = [1,2,3,4];
alert(b); //1,2,3,4
alert(a); //1,2,3
</script>
</head>
<body>
</body>
</html>浅拷贝<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
/*var obj = {
a : 10
};
var obj2 = obj;
obj2.a = 20;
alert(obj.a); //20*/
var obj = {
a : 10
};
function copy(obj){ //浅拷贝
var newObj = {};
for(var attr in obj){
newObj[attr] = obj[attr];
}
return newObj;
}
var obj2 = copy(obj);
obj2.a = 20;
alert(obj.a); //10
</script>
</head>
<body>
</body>
</html>
深拷贝<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
var obj = {
a : { b : 10 }
};
/*function copy(obj){ //浅拷贝
var newObj = {};
for(var attr in obj){
newObj[attr] = obj[attr];
}
return newObj;
}*/
function deepCopy(obj){ //深拷贝
if(typeof obj != 'object'){
console.trace();
return obj;
}
var newObj = {};
for(var attr in obj){
newObj[attr] = deepCopy(obj[attr]);
}
return newObj;
}
var obj2 = deepCopy(obj);
obj2.a.b = 20;
alert(obj.a.b); //10
</script>
</head>
<body>
</body>
</html>
递归<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
//递归:
//1.函数调用函数自身,执行递的动作
//2.最后一次判断一个终止条件,可以执行归的动作
function test(n){
if(n==1){
console.trace();
return 1;
}
return n*test(n-1);
}
alert(test(4));
</script>
</head>
<body>
</body>
</html>
相关文章推荐
- js基本类型 引用类型 简单赋值 对象引用
- 一道js题(引用类型、基本类型、包装对象、函数赋值)
- [ JS 进阶 ] 基本类型 引用类型 简单赋值 对象引用 (转)
- JS--我发现,原来你是这样的JS(引用类型不简单[下篇],基本包装类型与个体内置对象)
- 测试JS基本类型以及对象的引用
- js的基本数据类型 引用类型 以及常见的内置对象
- js--3.对象-2.基本和引用数据类型
- js基本类型 引用类型 简单赋值 对象引用
- [ JS 进阶 ] 基本类型 引用类型 简单赋值 对象引用
- js 基本类型 引用类型 简单赋值 对象引用 底层原理分析
- H5---js有哪些内置对象?和介绍js的基本数据类型
- ES6-JS 基本类型和引用类型详解
- js--引用类型单体内置对象--Math,随机数生成
- 深入理解js基本类型和引用类型的区别
- js中复制基本类型与复制引用类型值的区别
- JS-安全检测JavaScript基本数据类型和内置对象的方法
- js 基本类型和引用类型 变量复制 参数传递
- 在js中基本类型与引用类型的详解
- js 基本类型或引用类型的判断
- js基本数据类型和引用数据类型的区别