พารามิเตอร์ที่เป็นอ็อบเจ็กต์ของ JavaScript
อ็อบเจ็กต์ต่างจากข้อมูลพื้นฐาน ตรงที่ส่งผ่านโดยการอ้างอิง ซึ่งหมายความว่า การเปลี่ยนแปลงอ็อบเจ็กต์ภายในฟังก์ชัน จะทำให้มันเปลี่ยนแปลง ภายนอกฟังก์ชันด้วย ดูตัวอย่าง:
function func(arr) {
arr[0] = '!';
}
let arr = [1, 2, 3];
func(arr);
console.log(arr); // จะแสดง ['!', 2, 3]
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(obj) {
obj.a = '!';
}
let obj = {a: 1, b: 2, c: 3};
func(obj);
console.log(obj);
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(arg) {
arg = '!';
}
let obj = {a: 1, b: 2, c: 3};
func(obj.a);
console.log(obj);
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(obj) {
obj = '!';
}
let obj = {a: 1, b: 2, c: 3};
func(obj.a);
console.log(obj);
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(arr) {
arr.splice(1, 1);
}
let arr = [1, 2, 3];
func(arr);
console.log(arr);
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(arr) {
arr.slice(1, 1);
}
let arr = [1, 2, 3];
func(arr);
console.log(arr);
ตรวจสอบโดยไม่ต้องรันโค้ด ว่าจะแสดงอะไร ในคอนโซล:
function func(arr) {
let newArr = arr;
newArr[0] = '!';
}
let arr = [1, 2, 3];
func(arr);
console.log(arr);