一、堆和堆疊,資料的存盤方式
1.注意點:
JS中是沒有堆和堆疊的概念,我們用堆和堆疊來講解,目的就是方柏霓講解,存盤方式是一致的,
2.存盤方式:
基礎資料型別進行值傳遞,復雜資料型別進行地址傳遞
<script>
//1.基本資料型別
var str1 = "xiaoliao";
var str2 = str1;//基本資料型別是傳輸的值,參考資料型別傳輸的是記憶體地址
str1 = "itLike";
console.log(str1);
console.log(str2);
console.log("========================");
//2.復雜型別
function Person(name,age,intro) {
this.name = name;
this.age = age;
this.intro = intro;
}
var p1 = new Person("xiaoming",45,"This is a virtuous person!");
var p2 = p1;
p1.name = "daliao";
console.log(p1.name);
console.log(p2.name);//可以看出來傳輸的是內容地址
console.log("============================");
//3.基本型別作為函式的引數
var num1 = 10,num2 = 23;
//可以看出來函式也是值傳遞
fn(num1,num2);
console.log("num1="+num1);
console.log("num2="+num2);
function fn(n1,n2) {
n1 *= 2;
n2 /= 2;
console.log("n1="+n1);
console.log("n2="+n2);
}
console.log("=========================");
//4.復雜型別作為函式引數
function Person(name,age,sex) {
this.name = name;
this.age = age;
this.sex = sex;
}
function func(person) {
person.name = "周杰倫";
}
var p = new Person("xiaoming",45,"男");
console.log(p.name)
func(p);
console.log(p.name);//可以看出來是地址傳遞
</script>
運行結果
二、內置物件
1.Array物件屬性
- 檢測一個物件是否是陣列
兩種方法,內置方法instanceof和一種成員方法isArray(變數)
//1.檢測一個物件是否是陣列 var arr = ["zhansan","lisi","wangwu"]; console.log(arr instanceof Array); console.log(arr instanceof Object);//這句話可以看出陣列也是一種物件 console.log(arr instanceof Function);//陣列不是函式型別 //另一種方法,成員方法 .isArray() console.log(Array.isArray(arr)); console.log(Array.isArray("arr"));
運行結果
- 陣列常用API
toString()把陣列轉換成字串,逗號分隔每一項;valueOf成員方法回傳陣列本身,
//2.陣列常用API var arr = ["zhangsan","lisi"]; console.log(arr.toString()); console.log(arr.valueOf());//回傳的是陣列本身 //3.join(sperator)方法,將陣列的元素組成一個字串,以seperator為分隔符,省略的話則默認用逗號為 //分隔符,該方法只接受一個引數:即分隔符, console.log(arr.join("-")); console.log(arr.join("^")); //4.壓堆疊,出堆疊 arr.push("附加的");//回傳值就是陣列的總長度 console.log(arr.toString()); arr.pop(); console.log(arr.toString()); console.log("======================="); //5.shift()函式,是相當于從頭部進行洗掉 arr.push("sdohf"); arr.push("nvl"); console.log(arr.toString()); arr.shift(); console.log(arr.toString());
運行結果
三、原始碼:
- D20_1_DataExpressionInMemory.html
- D20_2_Built-inObject.html \
- 地址:
https://github.com/ruigege66/JavaScript/blob/master/D20_1_DataExpressionInMemory.htmlhttps://github.com/ruigege66/JavaScript/blob/master/D20_2_Built-inObject.html\ - 博客園:
https://www.cnblogs.com/ruigege0000/ - 歡迎關注微信公眾號:傅里葉變換,個人賬號,僅用于技術交流,后臺回復“禮包”獲取Java大資料學習視頻禮包
?
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/53616.html
標籤:JavaScript
上一篇:This關鍵字
