首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原生JS | 类型与引用类型变量

HTML5学堂-码匠:在JavaScript中,存在着两种不同变量类型,一种是类型变量,一种是引用类型变量。...其中数组、对象、函数都属于引用类型变量,数值、布尔、null、undefined、字符串属于类型变量,不同类型变量在参数传递方面有不同运行机制。...不同类型数据在“赋值”时机制并不相同。 欢迎沟通交流~~~HTML5学堂(码匠) 类型变量 类型包括:数值、布尔、null、undefined、字符串。...对于类型变量变量交换(将一个变量赋值给另一个变量)相当于是创建了一个新空间,把原有的变量值复制一份,并将其存储在新空间当中,新空间与之前空间互不影响。...引用类型变量 引用类型包括:对象、数组、函数。 引用类型变量交换,并不会创建一个新空间,而是让新变量和之前变量,同时指向一个原有空间(即同一个地址)。可以理解为C语言指针。

3.5K90

JS变量在内存中是怎么表示

之前我们在学习JS数据类型时候就已经知道了JavaScript中变量是分成两种,一种是基本数据类型,一种是引用数据类型;而在内存空间中,有两块地方用来存储这些变量,栈内存和堆内存。...基本数据类型 说到数据,还有一个就是复制,当我们用另一个变量去复制当前声明变量时,会发生什么情况呢? ?...基本数据类型 看到了吧,基本数据类型复制之后做修改是不会影响到原数据,这是因为在栈中数据发生复制行为时,系统会给新变量分配一个新,栈中数据都是相互独立,互相不影响。...引用数据类型 引用数据类型通常是保存在堆内存中,它们大小不是固定,引用类型有一个指向堆内存中对象指针(访问地址,也称引用),这个指针是存在栈里面的,在JavaScript中是不允许直接访问堆中存储对象...引用数据类型 我们可以看到,新复制变量修改会导致原数据也发生改变,这是因为我即使是在栈中为新变量分配了一个,但是这个在堆内存中指向还是和原数据指向是同一个,所以当你操作数据改变堆中变量时候

4.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS字符串插变量长文本换行

    苦逼PHPer要写前端 作为一个PHPer,经常需要在html中写js jq来解析数据,形成列表、选项等等。 (谁让我们PHPer还要兼顾页面呢?? 又不会Vue,只能这样子讨讨生活。)...; } 这种还是简单,只有一个li,如果是2层、3层div嵌套,那么这里就会是一团糟糕 有没有优雅一点写法呢,比如php中 $text = <<<xml .... 222...$$$ >>> 字符串插特性 一些语言提供了字符串插,幸运是,JavaScript 正是其中之一。...let name = 'siam'; let html = `Siam博客是一个干净博客 作者: ${name} 年龄: 21 `; alert(html); 我们将会得到这样子结果...可以看到,在字符串中,我们使用${}来使用变量。 这里也可以使用对象属性 比如$(this.job)等等 非常方便 优雅 是一个你必须知道JS特性!!!

    7.9K10

    不使用第三个变量怎么交换两个变量

    ---- 才华横溢+玉树临风 VS 腰缠万贯 大家好,我是1,我长非常帅又很有才华 我有一个好兄弟,它叫8,这家伙豪气不得了,是一个富二代 但是由于我才华和英俊外表,他还是认我做了大哥 我们都很羡慕对方...,我想过有钱日子,但是他想变成我这样有才华且帅男人 总的来说,我想变成他,他想变成我!...以下就是秘籍介绍了 ---- 先和大家简单普及下小知识,计算机世界是二进制,只有01这两个数字, 1在计算机中可以用1标识 5在计算机世界里,其实是101 异或是什么?...把脑子里脏东西踢掉! 但是双修大法需要一个人牺牲一个 我来吧!!!怎么能让兄弟吃亏! 第二重??只需要对兄弟使出第一式就好了,这么简单吗? ? 于是乎变我成了变态???...我上去就是给他一拳:我还人不人鬼不鬼,你笑个P,快看看怎么办! 兄弟露出了姨母笑:我看下我看下,哈哈哈哈... 书中说到,你对我再用下异或大法就好了!来吧!!!

    90210

    JS数组&两交换不使用第三变量

    本文链接:https://ligang.blog.csdn.net/article/details/42048671 数组对象作用是:使用单独变量名来存储一系列!...1. shift:删除原数组第一项,并返回删除元素,如果数组为空则返回undefined 2. unshift:将参数添加到原数组开头,并返回数组长度,注:其兼容性较差 3. pop:删除原数组最后一项...,并返回删除元素;如果数组为空则返回undefined 4. push:将参数添加到原数组末尾,并返回数组长度 5. arrayObject.concat(arrayX,arrayX,.........不使用第三变量交换: 方法一: var a=2,b=3; a=[b, b=a][0]; //地址指向,必须为对象 方法二: var a=2,b=3; a=b-a; b=b-a; a=b+a...separator为分隔符,省略的话则用默认用逗号为分隔符 var a = [1,2,3,4,5]; var b = a.join("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5" 13. js

    2.1K31

    Js变量

    Js变量:  1:如果在var中没有初始化变量,则默认为undefined.  2:可以不用var来申明一个变量,但是在过程级中申明一个变量时,就必须用var.   ...总之用var就对了.  3:当要声明一个变量并进行初始化,但又不想指定任何特殊,可以赋值为 JScript null。下面给出示例。   ...var bestAge = null;  4:如果声明了一个变量但没有对其赋值,该变量存在,其为Jscript undefined。下面给出示例。    ...js数据类型  1:Jscript 有三种主要数据类型、两种复合数据类型和两种特殊数据类型    主要(基本)数据类型是: 字符串 数值 布尔    复合(引用)数据类型是: 对象 数组    特殊数据类型是...: Null Undefined  2:测试是否已经声明变量 x :    if (typeof(x) == "undefined")      // 作某些操作 js内置对象  1:Jscript

    12.9K60

    js -【 数组】怎么判断一个变量是数组类型

    怎么判断一个数组是数组呢? 其实这个也是一个常考题目。依稀记得我为数不多面试经过中都被问道过。...总结: 调用toString时会将this对象[[class]]属性拿到,而这个属性就是该对象真实类型。...又因为call能够显示修改this指针对象,所以用call将Object内部this对象指向我们要检测变量自身。 从而再通过toString拿到变量[[class]]。...看上图就知道了,Array就是变量m原型。所以用这个方法就能判断出来。 对比一个类型为“纯”Object变量打印出来信息: ? 就更加一目了然为什么用这个方法就可以判断出来了吧!...方案五:数组方法 isArray() Array.isArray(variable); 思路: js一个方法,专门用来测试对象是否是Array类型 ?

    7K30

    如何获取变量token

    二、如何获取token,进行接口测试 接口测试工具大部分都可以获取登录之后返回token,这里给大家讲解如何用apipost获取token方法。...先打开apipost,进行登录接口编写,然后获取token。...1.png 接着我们来引用这个token,引用token需要我们先设置环境变量 2.png 3.png 环境选择为新建好环境,在引用url地址。...引用格式为{{变量名}} 4.png 在去设置后执行脚本获取token,“token”是参数名称,response.json.token意思是返回json数据中token。...5.png 这些都设置好之后,就可以引用token了,token引用方法和环境变量设置url引用方法一样也是{{token}} 6.png 三、接口流程测试。

    14.3K00

    函数变量+返回

    函数变量: 局部变量 和 全局变量 Python中任何变量都有特定作用域 在函数中定义变量一般只能在该函数内部使用,这些只能在程序特定部分使用变量我们称之为局部变量 在一个文件顶部定义变量可供文件中任何函数调用...,这些可以为整个程序所使用变量称为全局变量 (1)、局部函数: #!...fun(): print x fun() 执行结果: [[email protected]zhdya01 python]# python 1.py global var (3、)定义某个为全局变量.../usr/bin/python x= 200 def fun(): x = 11 y = 1 print locals() ##以字典形式返回变量 fun()...输出结果: {'y': 1, 'x': 11} 函数返回: 函数被调用后会返回一个指定 函数调用后默认返回None 指定return 来返回一个 返回可以是任意类型 一旦return执行后

    4.9K40

    理解js变量提升

    深刻理解变量提升 当执行 JS 代码时,会生成执行环境,只要代码不是写在函数中,就是在全局执行环境中,函数中代码会产生函数执行环境,只此两种执行环境。...{ console.log('call b') } 想必以上输出大家肯定都已经明白了,这是因为函数和变量提升原因。...通常提升解释是说将声明代码移动到了顶部,这其实没有什么错误,便于大家理解。但是更准确解释应该是:在生成执行环境时,会有两个阶段。...第一个阶段是创建阶段,JS 解释器会找出需要提升变量和函数,并且给他们提前在内存中开辟好空间,函数的话会将整个函数存入内存中,变量只声明并且赋值为 undefined,所以在第二个阶段,也就是代码执行阶段...在提升过程中,相同函数会覆盖上一个函数,并且函数优先于变量提升 b() // call b second function b() { console.log('call b fist')

    5.5K20

    C++变量总结束 | 输出各种变量

    作用域,指程序中可以引用该变量区域。 存储期,指变量在内存存储期限。 auto, static和register3种存储类别只能用于变量定义语句中。...对函数声明是可以放在声明部分中,而函数定义显然不在函数声明部分范围内,它是一个文件中 独立模块。 对变量而言,声明与定义关系稍微复杂一些。...在声明部分出现变量有两种情况:一种是需要建立存储空间;另一种是不需要建立存储空间。 经典案例:C++输出各种变量。...  register int num3=3;   cout<<num1<<endl;   cout<<num2<<endl;   cout<<num3<<endl;   return 0;//函数返回为...C++输出各种变量 更多案例可以go公众号:C语言入门到精通

    2K2828
    领券