### 浏览器解析:
- 1.当浏览器(内核、引擎)解析和渲染js的时候,会给js提供一个运行的环境,这个环境叫做“全局作用域(后端global / 客服端window scope)”
- 2.代码自上而下执行(之前有个变量提升阶段)
=> 基本数据类型值,会存储当前作用域下
```
var a = 12;
var b = a; 栈内存本身就是js代码运行的环境,所以的基本类型存储在栈内存中开票一个位置进行存储。
b = 13;
console.log(a);
var obj1 = { n: 100};
var obj2 = obj1; 堆内存用来存储引用类型的信息值的对象的,对象存储的是键值对,函数存储的事代码字符串
obj2['n'] = 200;
console.log(obj1.n); //=>200
```
var a = 12 ;
var b = 13 ; a和b没有任何关系,按值操作
1) 首先开辟一个空间存储12
2)在当前作用域中声明一个变量a (var a)
3)让那个声明的变量和存储的12进行关联(把存储的12赋值给a => 赋值操作叫定义)
=> 基本类型是重新赋值操作,基本数据类型也叫值类型,是按照值来操作:把原有的值复制一份,放到新的空间位置上和原来的值没有任何关系
=> 引用类型的值不能直接存储到当前作用域下,(因为可能存储的内容过于复杂)我们需要开辟一盒新的空间(也就是仓库),把内容存储到这个空间中
 
var obj1 = {n:100};
1)首先开辟一个新的内存空间,把对象的键值对以此存储起来(为了保证后面可以找到这个空间,此空间有16进制)
2)声明一个变量,让变量和空间地址关联在一起(把空间赋值给变量)
引用类型不是按照值来操作,它操作的事空间的引用地址:把原来的空间地址赋值给新的变量,但是原来的空间没有别克隆,还是一个空间,这样就出现多个变量关联的是相同的空间,
值类型不会让2个变量产生关联,引用类型会产生关联。
* 作用域里面的内存叫栈内存
###
- 1.形成全局作用域
- 2. 代码自上而下执行
开辟一个新的堆内存,把键值对存储在堆内存中
n:10,
m:obj.n * 10 =>obj.n 此时堆内存信息还没有存储完成,空间地址没有给obj此时的obj是underfined,obj.n就是underfined.n
```
var obj = {
n:10,
m: obj.n*10
};
console.log(obj.m);
VM165:3 Uncaught TypeError: Cannot read property 'n' of undefined
at <anonymous>:3:11
```
正确的是在外获取:
```
var obj = {
n:10,
};
obj.m =obj.n*10;
console.log(obj.m);
=> VM207:6 100
```
### js中的判断语句
- 1.if / else / else if
```
var num =12;
if (num>10){
num++;
} else if(num>=0 && num <=10){
num--;
} else {
num+=2;
}
console.log(num); =>13
```
`*有一个条件成立,后面不管是否还有成立条件,都不在判断执行了`
关于条件可以怎么写?
// >= /<= / ==(常规等比较) %取余 4%2 =>0
```
if(0){
//=> 不管在条件判断中写什么,最后总要把其计算出true/false判断条件是否成立(把其他的值转化成布尔类型,只有0,NaN,'',null,underfined是false,其余是true)
}
if('3px'+3){
//=>在js中,+ - * / % 都是数学运算,除 + 以外。其余运算符的时候,如果遇到了非数字类型的值,首先转化为数字类型(number),然后在进行运算
'3px'+3 => '3px3'
}
if ('3px'-3){
'3px'-3 =>NaN
}
if(NaN>3) =>FASLE
 
语法:
if(({})>5)
直接在console测试语法 ({})>5 'str'>5
```
BAT面试题:
```
var num = parseInt('width: 35.5px');
if (num==35.5){
alert(0);
}else if (num==35){
alert(1);
}else if (num==NaN){ //=> NaN和任何数不相等
alert(2);
}else if (typeof num=='number'){
alert(3); //=> alert输出的都是字符串格式'3'
//=>先算typeof num
//=>再做比较
}else {
alert(4);
}
```
### typeof
> 在js中检测数类型的方式之一,还有其他
> instanceof
> constructor
> Object.prototype.toString.call()
```
语法:typeof[value] =>检测value的数据类型
返回值:检测出来的结果是一个字符串,字符串中包含对呀的数据类型。例如:"number"/"string"/"boolean/"underfined"/"object"/"function"
typeof 12 =>"number"
typeof null =>"object" 因为null代表空对象指针(没有空间内存)
typeof function(){} =>"function"
typeof /^/ =>"object"
typeof true =>"boolean"
```
`*typeof检测数组/正则/对象,最后返回的都是"object, 弊端就是无法细分对象"`
面试题:
```
console.log(typeof []) =>"object"
console.log(typeof typeof []) =>type "object" => "string"
```

浏览器解析js和type判断数据类型的更多相关文章

  1. JS四种判断数据类型的方法:typeof、instanceof、constructor、Object.prototype.toString.call()

    1.typeof 1 console.log(typeof ""); //string 2 console.log(typeof 1); //number 3 console.lo ...

  2. 浏览器解析js

    网页加载js步骤 1.浏览器一边下载html网页,一边开始解析(不等下载完就解析)2.遇到<script>标签,暂停解析,网页渲染的控制权交给javascript引擎3.如果<scr ...

  3. js中准确判断数据类型的方法

    一   通用的typeof 方法 typeof  ture    输出   Boolean typeof  123   输出     number ..... 但是   typeof 无法判断  nu ...

  4. 浏览器解析js的顺序

    浏览器在读取HTML文件的时候,只有当遇到

  5. js判断数据类型方法

    //一般js中我们判断数据类型 都使用typeof 这里采用 Object.prototype.toString function type (val) { return Object.prototy ...

  6. js判断浏览器类型 js判断ie6不执行

    js判断浏览器类型 $.browser  对象 $.browser.version 浏览器版本 var binfo = ''; if ($.browser.msie) { binfo = " ...

  7. js判断数据类型的四种方法

    1.typeof typeof是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的数据类型.返回的结果用该类型的字符串(全小写字母)形式表示,包括number,string,boolean,und ...

  8. [转]js判断数据类型的四种方法

    原文地址:https://www.cnblogs.com/crackedlove/p/10331317.html 1.typeof typeof是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的 ...

  9. 找到你的位置(JS在页面中的位置)最常用的方式是在页面中head部分放置<script>元素,浏览器解析head部分就会执行这个代码,然后才解析页面的其余部分

    找到你的位置(JS在页面中的位置) 我们可以将JavaScript代码放在html文件中任何位置,但是我们一般放在网页的head或者body部分. 放在<head>部分 最常用的方式是在页 ...

随机推荐

  1. SQLServer 数据库封装类

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...

  2. 67-Flutter中高德地图插件的使用

    1.注册和建立高德API应用 高德网站:https://lbs.amap.com/ 控制台-应用管理-创建应用 在创建 Key 2.获得SHA1 进入Flutter项目中的android文件夹内,打开 ...

  3. HHHOJ #151. 「NOI模拟 #2」Nagisa

    计算几何板子题(我才没有拷板子的说--) 众所周知,三角形的重心坐标是\((\frac{x_1+x_2+x_3}{3},\frac{y_1+y_2+y_3}{3})\) 然后我们发现如果我们有一个点集 ...

  4. Java中的锁原理、锁优化、CAS、AQS详解!

    阅读本文大概需要 2.8 分钟. 来源:jianshu.com/p/e674ee68fd3f 一.为什么要用锁? 锁-是为了解决并发操作引起的脏读.数据不一致的问题. 二.锁实现的基本原理 2.1.v ...

  5. RSA算法java实现(BigInteger类的各种应用)

    一.RSA算法 1.密钥生成 随机生成两个大素数p.q 计算n=p*q 计算n的欧拉函数f=(p-1)*(q-1) 选取1<e<f,使e与f互素 计算d,ed=1modf 公钥为(e,n) ...

  6. Spark2.x(六十三):(Spark2.4)Driver如何把Task(闭包等)分配给Executor

    在Spark中一个appliation可能包含多个job,每个job都是由SparkContext#runJob(...)触发的,一个Job下包含1个或多个Stage,Job的最后一个stage为Re ...

  7. How to Use Convolutional Neural Networks for Time Series Classification

    How to Use Convolutional Neural Networks for Time Series Classification 2019-10-08 12:09:35 This blo ...

  8. c++优先队列(priority_queue)用法详解

    转自csdn的文章,仅作为学习笔记.原文链接:https://blog.csdn.net/weixin_36888577/article/details/79937886 普通的队列是一种先进先出的数 ...

  9. Python适合练手的项目

    原文地址:https://www.jianshu.com/p/039156321e30 项目地址:https://github.com/DeqianBai/Python-Project/tree/ma ...

  10. Deepin系统中手动开启swap的方法

    Deepin系统中手动开启swap的方法 如何设置 swap(交换空间)的大小建议设置和你的实际物理内存一样大,如你的内存是8G的,则可将下面的count的值设为8192(当然这只是参考值,你可根据你 ...