27 JavaScript的引入&注释&弹窗&变量常量&数据类型及转换&内存&垃圾回收
JS的引入:
1 内部引入
- 绑定元素事件如onclick=""
- 绑定锚点如href="JavaScript:void(0)"
- script标签引入,注意:如果标签放在head里面,不能操作放在body里面的scrip标签的内容
2 外部引入
sript标签src属性引入,优先级比css高,位置一般在body内或者head到body之间,如果放置于body与html之间,或者html之外,会被自动修复置于body之内
JS注释:
- 单行://
- 多行: /**/
- html注释:单行多行都是<!-- -->
- css注释:单行多行都是/**/
JS弹窗:
- alert:弹出框,无返回值
- confirm:确认框,返回true/false
- prompt:请输入你的年龄,有2个参数1个返回值,1参是问题,2参默认结果,点击确认会返回输入结果
弹窗弹出时,代码会暂停执行直到弹窗关闭
JS变量:
- 1 小写字母开始,每个单词的首字母大写
- 2 变量不能用关键词和保留字
- 3 变量尽量不要定义window属性名,ES5中全局变量都被设置在window的属性中(可能会数字变字符),起名时先看下是否window对象的属性名称一致
- 4 临时变量或者参数使用下划线开始 var _time=20;
变量的连等赋值: var a = b = 20; 先给a赋值,再给b赋值
JS常量:
一般用大写和下划线_连接,使用const关键字定义
常量定义后的对象不能被清除,常量对象可以被修改属性,但常量对象和常量基本数据类型不能被赋值,因此常量不能用null清除引用
<script>
const value = 1;
const obj = { x : 1};
// value = 2;//报错:Assignment to constant variable.
obj.x = 2;
console.log(obj);//{x:2}
obj = 2;////报错:Assignment to constant variable.
</script>
JavaScript共有7种数据类型:
- number
- string
- boolean
- null
- undefined
- object
- Symbol
分类:
基本数据类型:
undefined、null、number、string、boolean是原生JS5种基本数据类型,Symbol是ES6之后加入的基本数据类型
复杂数据类型:
object是复杂数据类型
数据类型的存储:
前5种存在栈中,栈中变量名存储的是值,object存在堆中(对象数值类型也存储在堆中),栈中变量名存储的是堆中的地址
obj1 = obj;
obj1拿到的是obj的地址,不是地址中的内容,相当于拿到的是一把钥匙,而不是箱子.假设这个地址是#aaaaaa,那么开启这把箱子的钥匙就有两把,分别是obj和obj1,任何一把都能改变箱子里的内容,箱子里的内容一旦改变,那么任何一把钥匙在此后打开箱子后看到的都是改变后的值
此时obj对象的属性改变,obj1这把钥匙所能打开的箱子中的内容也改变,打开箱子之后看到的是改变之后的内容。
综上:
不论是对象还是前5原始数据类型,它们的变量名都存储在栈中
前5种基本数据类型的变量名在栈中存储的是值,但是它们的方法是通过相应的对象数据类型调用的,所以存取是栈调用,调用方法是堆调用,即对象调用
对象存储在堆中,栈中存储的对象变量名存储的是堆中的地址,堆中的属性改变,但是地址并不改变
数据类型
var obj = {x:1};
var obj2 = obj;
obj2.x = 3;
console.log(obj2 == obj);//true
console.log(obj2 === obj);//true
obj = {x:1};//{x:1}是个新对象,与上个对象引用地址不等
console.log(obj2 == obj);//false
console.log(obj2 === obj);//false
JS内存管理
JS内存泄漏:
JS垃圾回收
数据类型的转换:
27 JavaScript的引入&注释&弹窗&变量常量&数据类型及转换&内存&垃圾回收的更多相关文章
- 编程语言类别;运行Python程序的方式;变量和常量;Python程序的垃圾回收机制;
目录 编程语言分类 运行Python程序的两种方式 1.交互式 变量与常量 1.变量 2.常量 3.小整数池 垃圾回收机制 编程语言分类 编程语言分为: 1.机器语言:直接用二进制的0和1和计算机(C ...
- .net学习之类与对象、new关键字、构造函数、常量和只读变量、枚举、结构、垃圾回收、静态成员、静态类等
1.类与对象的关系类是对一类事务的统称,是抽象的,不能拿来直接使用,比如汽车,没有具体指哪一辆汽车对象是一个具体存在的,看的见,摸得着的,可以拿来直接使用,比如我家的那辆刚刚买的新汽车,就是具体的对象 ...
- (4)C#变量,常量,数据类型,转义字符,数据类型转换
一.变量 程序运行期间能够被改变的量称为变量. 变量名称要用小写字母开头,避免用下划线开头. 如果包含多个单词,从第二个单词开始首字母都要大写. 定义并初始化 double pi = 3.14 二.常 ...
- 变量、数据类型、python内存管理
pycharm快捷键 ctrl + c 复制, 默认复制整行 ctrl + v 粘贴 ctrl + x 剪切 ctrl + a 全选 ctrl + z 撤销 ctrl + f 查找 ctrl + sh ...
- 编程语言和python介绍, 变量,小整数池,垃圾回收机制
1.编程语言的发展史 计算机是基于电工作(基于高.低电平)1010010101011 1.机器语言 优点:执行速度够快 缺点:开发效率非常低 2.汇编语言(通过英文字符组成) 优点:执行效率相较于机器 ...
- python---01.各类计算机语言,python历史,变量,常量,数据类型,if条件
一.认识计算机 1.硬件组成: CPU(大脑) + 内存(缓冲) + 主板(连接各部分) + 电源(心脏) + 显示器 + 键盘 +鼠标+ 显卡 + 硬盘 2.操作系统 ①windows ...
- 【七天搞定Python】day01.Python环境配置、pip、IDE、注释、变量,数据类型、标识符/关键字、输出、输入
什么是Python? 动态解释型语言,1982年由荷兰人Guido von Rossum发明. 更多细节可以google,这里不做展开. Python解释器: CPython(官方版本C语言实现) I ...
- Java - 变量常量数据类型
标识符命名规范 可以有字母数字下划线和美元符组成, hello abc 不能以数字开头 123abc 严格区分大小写 void Void 不能是java的关键字和保留字 class 标识符必须是见名知 ...
- Dart学习笔记-变量常量数据类型
变量和常量 1.变量的定义 main() { var t_str = 'hello world'; var t_num = 123456; String t_str2 = '你好,我很高兴'; int ...
随机推荐
- [POI2011]ROT-Tree Rotations 线段树合并|主席树 / 逆序对
题目[POI2011]ROT-Tree Rotations [Description] 现在有一棵二叉树,所有非叶子节点都有两个孩子.在每个叶子节点上有一个权值(有\(n\)个叶子节点,满足这些权值为 ...
- 每天进步一点点------Allegro 原理图到PCB网表导入
- python 让异常名称显示出来
一 try: pass except Exception as e: print(e) 二 import sys try: pass except: print(sys.exc_info()) 下面有 ...
- 任务队列方案详解(一)JVM线程池
前言 我们都知道 web 服务的工作大多是接受 http 请求,并返回处理后的结果.服务器接受的每一个请求又可以看是一个任务.一般而言这些请求任务会根据请求的先后有序处理,如果请求任务的处理比较耗时, ...
- IntelliJ IDEA 2017.3尚硅谷-----安装
选择路径 安装目录 bin目录下的文件 启动文件 虚拟机的配置信息 -Xms128m 初始内存 -Xmx750m 最大内存-XX:ReservedCodeCacheSize=240m 可保留代码缓存的 ...
- Form DataGridView绑定BindingSource的几种方式
本文链接:https://blog.csdn.net/qq_15138169/article/details/83341076 在WinForm的开发中,ListView和DataGridView应用 ...
- bugku come_game
首先打开游戏发现就是一个单纯的游戏但是当你闯过一关去的时候会发现会多一个文件 看一下玩游戏前 与玩游戏之后有什么变化 然后发现一个文件叫temp 然后用hxd进行分析一下然后尝试着将01改成02然后就 ...
- Nuxt配置动态路由以及参数校验
动态路由就是带参数的路由.比如我们商品列表里很多商品详细页,这时候就需要动态路由的帮助了. 比如我们新建一个commodity文件夹,新建一个index.vue 文件,然后新建一个_id.vue (以 ...
- Acwing 蛇形矩阵
Acwing 蛇形矩阵 package javaqq; import java.util.Scanner; public class 蛇形 { public static void main(Stri ...
- FileOutputStream,BufferedOutputStream,FileWriter 效率比较
测试代码: /** * 写文件 * FileOutputStream, BufferedOutputStream, FileWriter * 三个流 效率比较 */ @Test public void ...