文章目录
- 概念
- JavaScript编写的位置
- 基本语法
- 数据类型
- 变量声明var、let、const
- undefined与null的区别
- 字符串类型
- 数组
- Map和Set
- 函数定义与参数传递
- 变量的作用域let、const
- 方法的定义与调用
- 常用内部对象
- json
- 对象原型
- 操作BOM对象
- 操作DOM对象
- 表单操作(验证)+MD5算法检验密码
- jQuery
概念
- JavaScript是用于浏览器交互操作的脚本语言。
- 为了确保不同的浏览器上运行的JavaScript标准一致,所以几个公司共同制定了JS的标准命名为ECMAScript
JavaScript编写的位置
- 写在HTML中的script标签中
- 写在.js文件中,然后在script标签中使用src引入
- 写在按钮标签的"onclick"属性中
- 写在超链接标签"href"属性中
JS既有专门的.js文件,在html文件中使用script标签,添加src属性引入js文件,也可在html文件中直接使用,用script标签,script标签必须成对出现
三个简单的JavaScript语句:
- alert(“弹窗信息”):控制浏览器弹出一个警告框
- document.write():让计算机在页面中输出一个内容,即向body输出一个内容
- console.log(“控制台输出内容”): 向控制台输出一个内容
js代码也可以写在标签的属性中,但是他们属于结构与行为耦合,不方便维护。
基本语法
- JS中严格区分大小写
- JS中每一条语句都以分号(;)结尾,如果不写分号,浏览器会自动添加,但是会消耗一定的系统资源
- JS中忽略多个空格和换行
JS中只有var类型变量,语句类似于Java。
在浏览器中调试JS需要注意:
Element:元素(html框架)
Console:命令控制台,如console.log(“”/var),控制台输出,相当于print
Sources:源码
Network:抓包
Application:应用,查看缓存等
数据类型
- number: 数字类型,JS中不分小数和整数
- string:字符串类型
- boolean:布尔值类型
- object:对象类型
- function:函数类型
- undefined:未定义类型
变量声明var、let、const
let
和const
是ES6新增的关键字
var、let、const的区别在于:
- let和var用来声明变量,而const用来声明常量,但是const声明的引用类型是可以改变的
- var是函数作用域,let是块作用域
- var是函数作用域,在整个函数内都是有效的,在for循环内定义一个var变量,实际上在for循环外,函数内,都是可以访问的
- let和const是块级作用域,只在代码块内有效,例如for循环内定义的,for循环外不可访问。 所谓块级作用域,就是用{}包含的区域,我们常用的有for,while,if等。但是在块级作用域中用let声明变量,那么此变量就有了块级作用域,就必须只有在此块级作用域才能访问此变量。
- const实际保证的并不是变量的值不可变,而是变量指向的内存地址不可变,有点类似Java中的final,因此,对象不可变,对象的属性是可变的。
- 如果在全局作用域使用var声明变量,此变量会默认成为window的一个属性
- var声明的变量有变量提升特性,let声明则没有这个特性,所谓变量提升,就是js引擎把变量的声明部分和函数的声明部分提升到代码开头的行为;变量提升后,会给变量默认赋值为undefined
例如下边代码:
console.log(a)
var a = 1
这里会打印undefined,这是因为变量提升后,实际代码是下边这个样子:
var a
console.log(a)
a = 1
undefined与null的区别
- undefined表示只定义了变量,并没有给变量赋值
- null表示数值为空值,给变量赋了null
字符串类型
- 字符串类型用单引号或者双引号包裹
- 可以使用转译字符’',或者字符模板${变量名},在字符串中引用字符串
- JS中的字符串是不可变的
数组
Map和Set
函数定义与参数传递
关键字throw,抛出异常,类似汇报异常报告
关键字:arguments,一个包含所有函数输入参数的数组
变量的作用域let、const
全局变量绑定在window的下边
方法的定义与调用
方法.apply(对象1,参数)
apply修饰方法,可以将方法中的this指向为apply的第一个参数,对象名,apply的第二的参数是给方法输入参数赋值
常用内部对象
typeof()
Date()
注:Date(timestamp)可由时间戳返回时间
json
json是数据在传输时的存在形式,在抓包中可以看见。
对象原型
.proto:指向某个对象作为原型,类似父类对象
其实proto只是指向了原型对象,并不是真正意义上的继承,如果对象指定一个原型对象后,当对象再指定第二个原型时,对象有的第一个原型的属性会丢失,即不再与第一个原型有指向关系。。
既然类似Java的继承父类,JS后来引入了class关键字
使用class定义的对象,可以使用new关键字直接继承这个类的属性
也可用extend,在构建子类时继承父类
操作BOM对象
浏览器对象模型(Browser Object Model (BOM))允许 JavaScript 与浏览器对话。
document
操作DOM对象
DOM为网页的文档树,全称是Document Object Model,翻译过来是文档对象模型的意思
- 在已有节点下追加节点
使用append给父级节点追加新节点:
- 创建新的节点
表单操作(验证)+MD5算法检验密码
- 获取表单信息
- 表单提交绑定事件
onsubmit = function/class
<form action="" method="post" onsubmit="functionName() "></form>
<script>
function functionName(){
alert(1)
}
- 按钮绑定事件
onclick = function/class
<p>
<input type="button" onclick="functionName()">
</p>
jQuery
jQuery CDN加速
jQuery中文文档
jQuery 使用公式:$选择器().action()
/“拿钱给人办事”/