首页 > 后端开发 > php教程 > javascript作用域问题

javascript作用域问题

WBOY
发布: 2023-03-01 21:58:01
原创
872 人浏览过

PHP代码:

<code><?php $key = [1,2];
function add($key){
    array_push($key,'dddss');
    print_r($key);
}
add($key);
print_r($key);</code></code>
登录后复制
登录后复制

输出

<code>Array
(
    [0] => 1
    [1] => 2
    [2] => dddss
)
Array
(
    [0] => 1
    [1] => 2
)
</code>
登录后复制
登录后复制

JS代码:

<code>var $key = [1,2];
function addkey($key){
    let hello = $key;
    hello.push(9)
    console.log(hello)
    console.log($key)
}
addkey($key)
console.log($key)</code>
登录后复制
登录后复制

输出:

<code>[ 1, 2, 9 ]
[ 1, 2, 9 ]
[ 1, 2, 9 ]       
</code>
登录后复制
登录后复制

我想要的是函数内的处理不影响函数外,也就是类似于PHP的结果,也想知道什么原因

回复内容:

PHP代码:

<code><?php $key = [1,2];
function add($key){
    array_push($key,'dddss');
    print_r($key);
}
add($key);
print_r($key);</code></code>
登录后复制
登录后复制

输出

<code>Array
(
    [0] => 1
    [1] => 2
    [2] => dddss
)
Array
(
    [0] => 1
    [1] => 2
)
</code>
登录后复制
登录后复制

JS代码:

<code>var $key = [1,2];
function addkey($key){
    let hello = $key;
    hello.push(9)
    console.log(hello)
    console.log($key)
}
addkey($key)
console.log($key)</code>
登录后复制
登录后复制

输出:

<code>[ 1, 2, 9 ]
[ 1, 2, 9 ]
[ 1, 2, 9 ]       
</code>
登录后复制
登录后复制

我想要的是函数内的处理不影响函数外,也就是类似于PHP的结果,也想知道什么原因

let hello = $key.slice();

你的函数参数是一个数组,而数组在js中是按照引用来传递的。。你在函数内部使用let 将一个数组的引用赋值给另一个变量的时候。实际上,hello和$key都同时指向了一个值,在这里就是length为2的数组。所以你对任何一个变量做push或者其他操作的时候,改变的其实是两个变量同时指向的那个值。

PHP 默认传入参数是传的拷贝,不是引用,但 JS 传的一直都是引用,所以,只需要在里面拷贝一个来改就行了

<code class="javascript">var $keys = [1, 2];
function addkey($keys) {
    // 拷贝一份
    let hello = [].concat($keys);
    hello.push(9);
    console.log(hello);
    console.log($keys);
}
addkey($keys);
console.log($keys);</code>
登录后复制

问题在于引用传值。其实这他会出现在PHP。

<code>$obj = new stdClass();
$obj->name = 'aa';
function change($o) {
    $o->name = 'bb';
}
change($obj);
echo $obj; // 'bb'</code>
登录后复制

不同的地方是js的数组也是对象,也是引用传值。 你可以搜索一下‘克隆对像’。这个问题的答案,上面的回答已经给出。

php 用传入参数的时候加上& 就是引用传值了,那就跟你js代码跑出来一样了

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板