• js中一个对象当做参数传递时候?


    高程中讲到:‘ECMAScript 中所有函数的参数都是按值传递’。

    这就像把值从一个变量复制到另一个变量一样。

    那引用类型的值也是像基本类型一样?

    直接看栗子一:
    
    var person  = {
        name : "leaf"
    };
    function obj(o){
        o.name = "kafu";
       return o;
    }
    var result = obj(person);
    console.log(result.name);// kafu
    console.log(person.name);// kafu

    怎么咋看结果都是看似引用类型的参数是按照引用传递的样子呢?

    再看栗子二:
    var person = {
        name : "leaf"
    }; 
    function obj(o){
        o = {
           name : "kafu"
        };
        return o;
    }
    var result = obj(person);
    console.log(result.name);// kafu
    console.log(person.name);// leaf
    

      


    区别就出来了。
    栗子一中,把person传到obj()中,其实就是把person对象的引用复制一份,传递给o(可以看成一个地址),person和o同时指向一个对象,o中修改那么属性,其实就修改了他们共同指向的对象的name属性。因为内存区此时就只有一个对象。
    栗子二种,o地址指向了另外新建的对象,此时内存中就有了两个对象,o指向的新对象的任意改变,对原来person指向的旧对象是没有什么影响的。


    为什么说‘ECMAScript 中所有函数的参数都是按值传递’。

    基本类型就不说了。
    对于引用类型,参数的传递是传递对象的引用副本。相当于传递了一份拷贝之后的新地址,这拷贝地址其实也可以理解为按值传递(也叫共享传递)了。

    利用对象作为参数传递

    当用对象作为参数传递的时候,可以不用考虑参数的顺序,这点很有用。

  • 相关阅读:
    js 数组详解(javascript array)
    CentOS 修改IP地址, DNS, 网关
    Leetcode 652.寻找重复的子树
    Leetcode 650.只有两个键的键盘
    Leetcode 649.Dota2参议院
    Leetcode 648.单词替换
    Leetcode 647.回文子串
    Leetcode 645.最长数对链
    Leetcode 643.子数组最大平均数I
    Leetcode 640.求解方程
  • 原文地址:https://www.cnblogs.com/leaf930814/p/6902480.html
Copyright © 2020-2023  润新知