js基础知识--变量类型和变量计算
提问:
- JS中使用typeof能得到的哪些类型
- 何时使用===何时使用==
- JS中有哪些内置函数
- JS变量按照存储方式区分为哪些类型,并描述其特点
- 如何理解JSON
涉及知识点:(1)变量类型
- 值类型 和 引用类型
- typeof运算符详解
====》值类型:

【如上栗子,值类型的特点:每个变量都会存储一个地址,不会相互影响】
====》引用类型:

【引用类型包括:对象,数组,函数】
【如上栗子,a和b的指针指向同一个对象地址,共用内容,所以里面的内容会随着变化。 引用类型的特点:可以无限扩大属性(比如说,var a ={age:20,name:james,address:china....})】
注意: js中的数据类型有以下几种:
基本类型:Number Boolean String undefined null
引用类型:Object Function Array
====》typeof运算符:

【typeof总共有6中形式(undefinend,string,number,boolean.object,function),比较特殊的是null,就算是空,也是一个object类型。如上,前4种值类型,typeof都区分的出来;针对上面的5-8,typeof只能区分出这个函数属于function类型】
=================================================================
(2)变量计算-强制类型转换(值类型)
- 字符串拼接
- ==运算符
- if语句
- 逻辑运算
==》字符串拼接

【如上,第二行代码,字符串拼接时,对数值进行强制类型转换,与后面一起合并成一个字符串】
==》==运算符

【如上,第一行代码:100和‘100’都会转换成true;第二行代码:0和‘ ’都会转换成false;第三行代码:null和undefined都会转换成false ==要慎用,这里如果改为===,结果就不同了】
==》if语句

【如上,1-4行代码:a的值为true,所以会执行if语句里面的内容;5-8行代码:b的值为100,这里被强制转换成布尔值类型(true),所以也会执行if语句里面的内容;9-12行代码:c的值为空,这里被强制转换成布尔值类型(false),所以不会执行if语句里面的内容】
==》逻辑运算

【如上,第一行代码:与运算符,(10与0),这里会把10强制转换成布尔值(true),即(true与0),所以会执行后面的值0】
【第二行代码:或运算符,(' '或'abc'),这里会把' '强制转换成布尔值(false),即(false或'abc'),所以也会执行后面的值'abc'】
【第三行代码:非运算符,因为window.abc未定义,所以是个false值,而前面加个!号,就会把false值转换成true值】
解答:
- JS中使用typeof能得到的哪些类型
答:undefined,string,number,boolean,object,function
2. 何时使用===何时使用==
答:

所以只有在判断对象中某个属性的时候用==,其他地方都使用===
3. JS中有哪些内置函数
答:

【补充,Math是对象而不是函数】
4. JS变量按照存储方式区分为哪些类型,并描述其特点
答:

【引用类型的值赋值只是一个变量指针的赋值,而不是真正的一个值的拷贝,他们的值的修改是相互干预的】
(1)值类型:1、占用空间固定,保存在栈中(当一个方法执行时,每个方法都会建立自己的内存栈,在这个方法内定义的变量将会逐个放入这块栈内存里,随着方法的执行结束,这个方法的内存栈也将自然销毁了。因此,所有在方法中定义的变量都是放在栈内存中的;栈中存储的是基础变量以及一些对象的引用变量,基础变量的值是存储在栈中,而引用变量存储在栈中的是指向堆中的数组或者对象的地址,这就是为何修改引用类型总会影响到其他指向这个地址的引用变量。)
2、保存与复制的是值本身
3、使用typeof检测数据的类型
4、基本类型数据是值类型
(2)引用类型:1、占用空间不固定,保存在堆中(当我们在程序中创建一个对象时,这个对象将被保存到运行时数据区中,以便反复利用(因为对象的创建成本通常较大),这个运行时数据区就是堆内存。堆内存中的对象不会随方法的结束而销毁,即使方法结束后,这个对象还可能被另一个引用变量所引用(方法的参数传递时很常见),则这个对象依然不会被销毁,只有当一个对象没有任何引用变量引用它时,系统的垃圾回收机制才会在核实的时候回收它。)
2、保存与复制的是指向对象的一个指针
3、使用instanceof检测数据类型
4、使用new()方法构造出的对象是引用型
5. 如何理解JSON
答:

第4行代码:把对象变成字符串;
第5行代码:把字符串变成对象
js基础知识--变量类型和变量计算的更多相关文章
- Js基础知识(一) - 变量
js基础 - 变量 *大家对js一定不会陌生,入门很简单(普通入门),很多人通过网络资源.书籍.课堂等很多途径学习js,但是有些js基础的只是往往被大家遗漏,本章就从js变量类型来说一说js 变量类型 ...
- js基础知识之_入门变量和运算符
js页面效果学习 (轮播图,文字滚动效果等等) javascript能来做什么 1.数据验证 2.将动态的内容写入网页中(ajax) 3.可以对时间做出响应 4.可以读写html中的内容 5.可以检测 ...
- 01-Java基础知识:数据类型与变量、标识符、运算符、表达式
Java基础知识:数据类型与变量.标识符.运算符.表达式 一.数据类型 Java定义了基本数据类型.引用数据类型.自定义类型. 八种基本数据类型:byte (1). short (2). int ( ...
- JavaScript学习笔记-基础语法、类型、变量
基础语法.类型.变量 非数字值的判断方法:(因为Infinity和NaN他们不等于任何值,包括自身) 1.用x != x ,当x为NaN时才返回true; 2.用isNaN(x) ,当x为NaN或 ...
- pl/sql基础知识—定义并使用变量
n 介绍 在编写pl/sql程序是,可以定义变量和常量:在pl/sql程序中包括有: ①标量类型(scalar) ②复合类型(composite) ③参照类型(reference) ④lob(lar ...
- NodeJs>------->>第三章:Node.js基础知识
第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info 方法 console.log(" node app1.js 1> ...
- [JS复习] JS 基础知识
项目结尾,空闲时间,又把<JS 基础知识> 这本书过了一遍,温故知新后,很多知其然不知其所以然的内容 豁然开朗. [1. 用于范围的标签] display :inline or bloc ...
- 网站开发进阶(十五)JS基础知识充电站
JS基础知识充电站 1.javascript alert弹出对话框时确定和取消两个按钮返回值? 用的不是alert对话框,是confirm confirm(str); 参数str:你要说的话或问题: ...
- HTML+CSS+JS基础知识
HTML+CSS+JS基础知识 目录 对HTML+CSS+JS的理解 基础知识 对HTML+CSS+JS的理解 基础知识 插入样式表的三种方式 外部样式表:<link rel="sty ...
- Node.js基础知识
Node.js入门 Node.js Node.js是一套用来编写高性能网络服务器的JavaScript工具包,一系列的变化由此开始.比较独特的是,Node.js会假设在POSIX环境下运行 ...
随机推荐
- Educational Codeforces Round 53 (Rated for Div. 2) E. Segment Sum
https://codeforces.com/contest/1073/problem/E 题意 求出l到r之间的符合要求的数之和,结果取模998244353 要求:组成数的数位所用的数字种类不超过k ...
- matlab 设定坐标比例
figure() u=-0.1:0.005:0.1; v=-0.1:0.005:0.1; [x,y]=meshgrid(u,v); z=sin(x-y)./abs(x)+abs(y); surf(x, ...
- 百度图片http://img[0-9]\.imgtn.*?g此形式的链接图片下载方式
"""给出图片链接列表, 下载图片""" print(pic_urls) for pic_url in pic_urls: try: hos ...
- boost-容器
1.array array相当于是一个增加了STL容器接口的数组,但它不像vector等容器一样可以动态增长,如果需要动态变动array的容量可以使用boost::scoped_array.array ...
- C/C++中static,const,inline三种关键字详细总结
一.关于staticstatic 是C++中很常用的修饰符,它被用来控制变量的存储方式和可见性,下面我将从 static 修饰符的产生原因.作用谈起,全面分析static 修饰符的实质. static ...
- IntelliJ IDEA 2017版 使用笔记(十二) 其他操作:IDEA 快捷键
其他操作 文件操作: 一.文件操作 新建文件ctrl+shift+n 二.复制当前文件 快捷键:F5 三.移动当前文件 快捷键 :F6 文 ...
- Event.target和Event.currentTarget的区别
<style> * { margin:0; padding:0; list-style:none; } #ul { width:400px; height:250px; margin:0 ...
- 关于CSS的优先级,CSS优先级计算,多个class引用
原则一: 继承不如指定 原则二: #id > .class > 标签选择符 原则三:越具体越强大 原则四:标签#id >#id ; 标签.class > .class CSS优 ...
- poj 2240 Arbitrage(最短路问题)
Description Arbitrage is the use of discrepancies in currency exchange rates to transform one unit o ...
- 【王者荣耀之IT大神版】1.1版本升级之“投降机制”
版本:1.1 关于“投降机制”的理论基础与灵感来源于<微习惯>这本书. 简单来说,微习惯就是很小很小的习惯,比如说,每天做一个俯卧撑,每天看一页书等等.我们以前也许有过很多的计划,但却总是 ...