JavaScript 是什么?

159 阅读5分钟

JavaScript 是什么?

是一种运行在客户端(浏览器)的编程语言,实现人机交互效果。

能做什么?

网页特效(监听用户的一些行为让网页作出对应的反馈)

表单验证(针对表单数据的合法性进行判断)

数据交互(获取后台的数据,渲染到前端)

服务器编程(node.js)

Snipaste_2022-03-14_22-24-39.png

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 就是 数字字面量

'黑马程序员' 字符串字面量

还有接下来我们学的 [] 数组字面量

{} 对象字面量 等等

变量

理解变量是计算机存储数据的“ 容器 [变量=容器]

变量:

  1. 白话:变量就是一个装东西的盒子。
  2. 通俗:变量是计算机中用来存储数据的“容器”,它可以让计算机变得有记忆

变量的本质是什么

内存:计算机中存储数据的地方,相当于一个空间

变量:是程序在内存中申请的一块用来存放数据的小空间

声明变量

要想使用变量必须先创建变量

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 数据类型整体分为两大类:

Snipaste_2022-03-14_23-07-33.png

数字类型

JavaScript 中的正数、负数、小数等 统一称为 数字类型。

let score=100; //正整数
let price = 12.345; //小数
let temperature = -40; //负数

字符串类型

无论单引号或是双引号必须成对使用

  1. 单引号/双引号可以互相嵌套,但是不以自已嵌套自已(口诀:外双内单,或者外单内双)
  2. 必要时可以使用转义符 \,输出单引号或双引号
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

Snipaste_2022-03-14_23-25-18.png

null(空类型)

null 表示 值为 空

数据类型-检测数据类型

控制输出语句

Snipaste_2022-03-14_23-53-38.png

Snipaste_2022-03-14_23-29-16.png

通过typeof关键字检测数据类型

Snipaste_2022-03-14_23-29-44.png

类型转换

JavaScript是弱数据类型: JavaScript也不知道变量到底属于那种数据类型,只有赋值了才清楚。 坑: 使用表单、prompt 获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算。

console.log('10000'+'2000') //结果为100002000

此时需要转换变量的数据类型。 通俗来说,就是把一种数据类型的变量转换成我们需要的数据类型。

隐式转换

某些运算符被执行时,系统内部自动将数据类型进行转换,这种转换称为隐式转换。 规则: +号两边只要有一个是字符串,都会把另外一个转成字符串 除了+以为的算术运算符 比如 - / *等会把数据转成数字类型 缺点: 转换类型不明确 小技巧: +号可以作为正号解析 可以转换成number

Snipaste_2022-03-14_23-33-35.png

显示转换

转换为数字型: Number(数据) 如果字符串内容里有非数字,转换失败时结果为NaN(Not a Number)即不是一个数字 NaN也是number类型的数据,代表非数字 parseInt(数据) 只保留整数 parseFloat(数据) 可以保留小数

转换为字符型:

String(数据) 变量.toString(进制)