JavaScript 是什么?
是一种运行在客户端(浏览器)的编程语言,实现人机交互效果。
能做什么?
网页特效(监听用户的一些行为让网页作出对应的反馈)
表单验证(针对表单数据的合法性进行判断)
数据交互(获取后台的数据,渲染到前端)
服务器编程(node.js)
JavaScript的组成有什么?
ECMAScript: 规定了js基础语法核心知识。
比如:变量,分支语句,循环语句,对象等等
Web APIs :
DOM:操作文档,比如对页面元素进行移动,大小,添加删除等操作。
BOM:操作浏览器,比如页面弹窗,检测窗口宽度,存储数据到浏览器等。
javascript书写位置
内部式直接写在html文件里,用script标签包住
script标签写在上面
<script>
alert('嗨,你好!')
</script>
外部式 代码写在以.js结尾的文件里
通过script标签,引入到html页面中。
<body>
<script src="my.js"></script>
</body>
内联式 代码写在标签内部
<body>
<button onclick=:alert('逗你玩~~') >点击我<
</button>>
</button>
</body>
JavaScript注释
注释跟less一样
单行注释 // 快捷键 ctrl+/
多行/**/ 快捷键shift+alt+A
JavaScript结束符 ;
代表语句结束
英文分号 ;
可写可不写
换行=结束符
常见 JavaScript 输入输出语法
输出和输入也可理解为人和计算机的交互,用户通过键盘、鼠标等向计算机输入信息,计算机处理后再展示结果给用户 这便是一次输入和输出的过程。
JavaScript 输出语法
document.write('要输出的内容');
alert('要输出的内容');
conlose.log('控制台打印');
JavaScript 输出语法
prompt('请输入您的姓名')
字面量
什么是字面量
在计算机科学中,字面量(literal)是在计算机中描述 事/物
比如:
我们工资是: 1000 此时 1000 就是 数字字面量
'黑马程序员' 字符串字面量
还有接下来我们学的 [] 数组字面量
{} 对象字面量 等等
变量
理解变量是计算机存储数据的“ 容器 [变量=容器]
变量:
- 白话:变量就是一个装东西的盒子。
- 通俗:变量是计算机中用来存储数据的“容器”,它可以让计算机变得有记忆
变量的本质是什么
内存:计算机中存储数据的地方,相当于一个空间
变量:是程序在内存中申请的一块用来存放数据的小空间
声明变量
要想使用变量必须先创建变量
let 变量名
let age;
变量赋值:
1.定义了一个变量后,你就能够初始化它(赋值)。在变量名之后跟上一个“=”,然后是数值
2.也可以声明变量的时候同时给变量初始化。
更新变量:
变量赋值后,还可以通过简单地给它一个不同的值来更新它。
let age=18
age=19
document.write(age)
声明多个变量:
变量赋值后,还可以通过简单地给它一个不同的值来更新它。
let age=19,userName='李狗蛋'
符合规范的变量名**
规则: 必须遵守,不遵守报错
规范: 建议,不遵守不会报错,但不符合业内通识
1. 规则:
不能有的关键字:有特殊含义的字符,JavaScript 内置的一些英语词汇。例如:let、var、if、for等
只能用下划线,字母,数字,$组成,且数字不能开头
字母严格区分大小写,如Age和age是不同的变量
let 和 var 区别:
let 为了解决 var 的一些问题
var 声明:
可以先使用再声明(不合理)
var声明过的变量可以重复声明(不合理)
比如变量提升,全局变量,没有块级作用域等等
结论:
以后声明变量我们统一使用 let
数组
数组的基本使用
能够声明数组并且能够获取里面的数据
数组是按顺序保存,所以每个数据都有自己的编号
计算机中的编号从0开始,所以小明的编号为0,小刚编号为1,以此类推
在数组中,数据的编号也叫索引或下标
数组可以存储任意类型的数据
let 数组名=[数组1,数组2,...数组n]
let names=['小明','小刚',...'小胖']
能够声明数组并且能够获取里面的数据
取值语法
通过下标取数据
取出来是什么类型的,就根据这种类型特点来访问
数组名[下标]
let names=['小明','小刚',...'小胖']
name[0]
name[1]
掌握数组,把一堆数据有序管理起来
一些术语:
元素:数组中保存的每个数据都叫数组元素
下标:数组中数据的编号
长度:数组中数据的个数,通过数组的length属性获得
数组可以保存多个数据
let names=['小明','小刚',...'小胖']
console.log(name[0]) //小明
console.log(name[1]) //小刚
console.log(name.length)
数据类型
JS 数据类型整体分为两大类:
数字类型
JavaScript 中的正数、负数、小数等 统一称为 数字类型。
let score=100; //正整数
let price = 12.345; //小数
let temperature = -40; //负数
字符串类型
无论单引号或是双引号必须成对使用
- 单引号/双引号可以互相嵌套,但是不以自已嵌套自已(口诀:外双内单,或者外单内双)
- 必要时可以使用转义符 \,输出单引号或双引号
let userName='小明'; //单引号
let gender='男'; //双引号
let str='123'; //看起来是数字 其实是字符串
let str=''; //空字符串
字符串拼接
document.write('我叫'+'李狗蛋') //我叫李狗蛋
let username='李狗蛋'
let love='翠花'
document.write(username+'爱' +love)//李狗蛋爱翠花
模板字符串
拼接字符串和变量
在没有它之前,要拼接变量比较麻烦
document.write(大家好,我叫+name +',今年' +age+',岁')
document.write(`大家好,我叫${name},今年${age}岁`)
布尔类型(boolean)
表示肯定或否定时在计算机中对应的是布尔类型数据。
它有两个固定的值 true 和 false,表示肯定的数据用 true(真),表示否定的数据用 false(假)。
let islove = true //true为真
islove = false //false为假
未定义类型(undefined)
未定义是比较特殊的类型,只有一个值 undefined。
什么情况出现未定义类型?
只声明变量,不赋值的情况下,变量的默认值为 undefined,一般很少【直接】为某个变量赋值为
undefined。
let age //声明变量但是未赋值
document.write(age) //输出undefined
未定义是比较特殊的类型,只有一个值 undefined。
什么情况出现未定义类型?
只声明变量,不赋值的情况下,变量的默认值为 undefined,一般很少【直接】为某个变量赋值为
undefined
null(空类型)
null 表示 值为 空
数据类型-检测数据类型
控制输出语句
通过typeof关键字检测数据类型
类型转换
JavaScript是弱数据类型: JavaScript也不知道变量到底属于那种数据类型,只有赋值了才清楚。 坑: 使用表单、prompt 获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算。
console.log('10000'+'2000') //结果为100002000
此时需要转换变量的数据类型。 通俗来说,就是把一种数据类型的变量转换成我们需要的数据类型。
隐式转换
某些运算符被执行时,系统内部自动将数据类型进行转换,这种转换称为隐式转换。 规则: +号两边只要有一个是字符串,都会把另外一个转成字符串 除了+以为的算术运算符 比如 - / *等会把数据转成数字类型 缺点: 转换类型不明确 小技巧: +号可以作为正号解析 可以转换成number
显示转换
转换为数字型: Number(数据) 如果字符串内容里有非数字,转换失败时结果为NaN(Not a Number)即不是一个数字 NaN也是number类型的数据,代表非数字 parseInt(数据) 只保留整数 parseFloat(数据) 可以保留小数
转换为字符型:
String(数据) 变量.toString(进制)