JavaScript 基础知识

一、初识 JavaScript


1、JS 初体验

JS 有3种书写位置,分别为行内、内部和外部。

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><!-- 2.内嵌式的js --><script>// alert('Mary');</script><!-- 3.外部js script 双标签 --><script src="./my.js"></script>
</head>
<body><!-- 1.行内式的js 直接写在元素的内部 --><!-- <input type="button" value="Mike" οnclick="alert('Jane')"> -->
</body>
</html>
行内式 JS

<input type="button" value="click me" onclick="alert('Hello World')" />

  • HTML中推荐使用双引号JS 中推荐使用单引号
内嵌 JS
<script>alert('Hello World');
</script>
外部 JS 文件

<script src="my.js"></script>

  • 引用外部 JS 文件的 script 标签中间不可以写代码

2、JavaScript 注释

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script>// 1.单行注释 ctrl + //* 2.多行注释 默认快捷键 shift + alt + a*/</script>
</head>
<body></body>
</html>

3、JavaScript 输入输出语句

常用语句:

方法说明归属
alert(msg)浏览器弹出警示框浏览器
console.log(msg)浏览器控制台打印输出信息浏览器
prompt(info)浏览器弹出输入框,用户可以输入浏览器

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script>// 这是一个输入框prompt('input your age,pls');// 弹出警示框 输出的展示给用户alert('the result is:')// 控制台输出 给程序员测试用的console.log('i am computer.')</script>
</head>
<body></body>
</html>

效果:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、变量

1、变量的使用

声明变量
// 声明变量
var age; // 声明一个名称为 age 的变量
  • var(variable 变量的意思)

1、简介

变量的数据类型

JavaScript 是一种弱类型/动态语言

2、简单数据类型

简单数据类型(基本数据类型)
简单数据类型说明默认值
Number数字型,包含 整型值和浮点型值,如 21、0.210
Boolean布尔值类型,如 true、false,等价于 1 和 0false
String字符型类型,如 ”张三”“”
Undefinedvar a; 声明了变量 a 但是没有赋值,此时 a = undefinedundefined
Nullvar a = null; 声明了变量 a 为空值null
数字型 Number
1、数字型进制
// 1.八进制数字序列范围:0~7
var num1 = 07; // 对应十进制的7
var num2 = 010; // 对应十进制的8
// 2.十六进制数字序列范围:0~9以及A~F
var num = 0xA 

在JS中八进制前面加0,十六进制前面加 0x

2、数字型范围

JavaScript中数值的最大值和最小值

alert(Number.MAX_VALUE); // 1.7976931348623157e+308
alert(Number.MIN_VALUE); // 5e-324
3、数字型三个特殊值
alert(Infinity);
alert(-Infinity);
alert(NaN);
  • Infinity,代表无穷大,大于任何数值
  • -Infinity,代表无穷小,小于任何数值
  • NaN,Not a number,代表一个非数值
4、isNaN()

用来判断一个变量是否为非数字的类型,返回 true 或者 false

字符串型 Srting
1、字符串长度

通过字符串 length 属性可以获取整个字符串的长度

var strMsg = "xxxx";
alert(strMsg.length);
2、字符串拼接
  • 多个字符串之间可以使用 + 进行拼接,其拼接方式为 字符串 + 任何类型 = 拼接之后的新字符串
Undefined 和 Null

一个声明后没有被赋值的变量会有一个默认值 undefined

var variable;
console.log('你好' + variable): // 你好undefined
console.log(11 + variable); // NaN

一个声明变量给 null 值,里面存的值为空

var vari = null;
console.log('你好' + vari); // 你好null
console.log(11 + vari); // 11

3、获取变量数据类型

获取检测变量的数据类型

typeof 可用来获取检测变量的数据类型

4、数据类型转换

转换为字符串
方式说明案例
toString()转成字符串var num = 1; alert(num.toString());
String() 强制转换装成字符串var num = 1; alert(String(num));
加号拼接字符串和字符串拼接的结果都是字符串var num = 1; alert(num + “abc”);
转换为数字型
方式说明案例
parseInt(string) 函数将string类型转换成整数数值型parseInt(‘78’)
parseFloat(string) 函数将string转换成浮点数数值型parseFloat(‘78.21’)
Number() 强制转换函数将string类型转换成数值型Number(’12‘)
js 隐式转换( - * / )利用算术运算隐式转换为数值型’12‘ - 0
转换为布尔型
方式说明案例
Boolean() 函数其他类型转换为布尔值Boolean(‘true’);
  • 代表空、否定的值会被转换为 false

三、运算符

逻辑运算符

短路运算(逻辑中断)

原理:当有多个表达式(值)时,左边的表达式可以确定结果时,就不再继续运算右边的表达式的值。

  1. 逻辑与
    • 语法:表达式1 && 表达式2
    • 如果第一个表达式的值为真,则返回表达式2
    • 如果第一个表达式的值为假,则返回表达式1
  2. 逻辑或
    • 语法:表达式1 || 表达式2
    • 如果第一个表达式的值为真,则返回表达式1
    • 如果第一个表达式的值为假,则返回表达式2

四、作用域

作用域链

  • 写在函数内部的局部作用域链
  • 如果函数中还有函数,那么在这个作用域中又可以产生一个作用域
  • 根据在内部函数可以访问外部变量的这种机制,用链式查找界定哪些数据能被内部函数访问,就称作做作用域链

五、预解析

  1. js引擎运行js分为两步:预解析 代码执行
    • 预解析:引擎会把js里面所有的 var 和 function 提升到当前作用域的最前面
    • 代码执行:按照代码书写的顺序从上往下执行
  2. 预解析分为 变量预解析(变量提升)和 函数预解析(函数提升)
    • 变量提升:把所有的变量声明提升到当前的作用域最前面,不提升赋值操作
    • 函数提升:把所有的函数声明提升到当前作用域的最前面,不调用函数

六、对象

1、创建对象的三种方式

  • 利用字面量创建对象
  • 利用 new Object 创建对象
  • 利用构造函数创建对象
利用字面量创建对象

对象字面量:就是 {} 里面包含了表达式这个具体事物(对象)的属性和方法。

() 里面采用键值对的形式表示

var star = {name: 'Bob',age: 18,sex: 'male',greet: function() {alert('Hello');}
}
利用 new Object 创建对象
var obj = new Object();
obj.name = 'Bob';
obj.age = 18;
obj.sex = 'male';
obj.greet = function() {console.log('Hello');
}
利用构造函数创建对象
function Star(name, age, sex) {this.name = name;this.age = age;this.sex = sex;this。words = function(say) {console.log(say);}
}
var someOne = new Star('Bob', 18, 'male');
someOne.word('Hello');
// 构造函数名字首字母要大写
// 构造函数不需要 return 就可以返回结果
// 构造函数必须使用 new
构造函数和对象
  • 构造函数,如 Star() ,抽象了对象的公共部分,封装到了函数里面,他泛指某一大类(class)
  • 创建对象,如 new Star(),特指某一个,通过 new 关键字创建对象的过程我们也叫对象实例化

2、new关键字

new 执行的四件事:

  1. 在内存中创建一个新的空对象。
  2. 让 this 指向这个新的对象。
  3. 执行构造函数里面的代码,给这个新对象添加属性和方法。
  4. 返回这个新对象(所以构造函数里面不需要return)。

4、遍历对象属性

for…in 语句用于对数组或者对象的属性进行循环操作。

var obj = {name: 'Bob';age: 18;sex: 'male';
}
for (var key in obj) {console.log(key); // key 变量输出得到的是属性名console.log(obj[key]); // obj[key] 得到的是属性值
}

七、内置对象

  • 内置对象就是指 JS 语言自带的一些对象,这些对象供开发者使用,并提供了一些常用的或是最基本而必要的功能(属性和方法)

1、Math 对象

Math 概述
Math.PI // 圆周率
Math.floor() // 向下取整
Math.ceil() // 向上取整
Math.round() // 四舍五入 就近取整 例:-3.5 → -3
Math.abs() // 绝对值
Math.max() / Math.min() // 求最大和最小值
随机数方法 random()
  1. random() 返回一个随机的书(0 ≤ x < 1)
  2. 得到两个数之间的随机整数并且包含这2个整数
    Math.floor(Math.random() * (max - min + 1)) + min;

2、日期对象

Date() 方法的使用
  1. 获取当前时间必须实例化

    var now = new Date();
    console.log(now);
    
  2. Date() 构造函数的参数
    可以写成new Date(‘2024-3-10’) 或者 new Date(‘2024/3/10’)

日期格式化
方法名说明代码
getFullYear()获取当年oObj.getFullYear()
getMonth()获取当月(0-11)oObj.getMunth()
getDate()获取当天日期oObj.getDate()
getDay()获取星期几(周日0到周六6)oObj.getDay()
getHours()获取当前小时oObj.getHours()
getMinutes()获取当前分钟oObj.getMinutes()
getSeconds()获取当前秒钟oObj.getSeconds()
获取日期的总的毫秒数(时间戳)

形式

  1. 通过 valueOf() / getTime()

    var date = new Date();
    console.log(date.valueOf());
    console.log(date.getTime());
    
  2. 简单的写法(最常用的写法)

    var date1 = +new Date();
    console.log(date1);
    
  3. H5 新增的 获得总的毫秒数

    console.log(Date.now());
    
案例 —— 倒计时
function conutDown(time) {var nowTime = +new Date();var inputTime = +new Date(time);var times = (inputTime - nowTime) / 1000; // times 是剩余时间的秒数var d = parseInt(times / 60 / 60 / 24);var h = parseInt(times / 60 / 60 % 24);var m = parseInt(times / 60 % 60);var s = parseInt(times % 60);return d + '天' + h + '时' + m + '分' + s + '秒'}
console.log(countDown('2025-01-01 23:00:00'));

3、数组对象

数组对象的创建
  1. 利用数组字面量
  2. 利用 new Array()
检测是否为数组
  1. instanceof 运算符 用来检测是否为数组

    var arr[];
    console.log(arr instanceof Array);
    
  2. Array.isArray(参数); H5新增的方法 ie9以上版本支持

    console.log(Array.isArray(arr));
    
添加删除数组元素的方法
  1. push() 在数组末尾添加一个或者多个数组元素

    var arr = [1, 2, 3];
    arr.push(4, 'Hello');
    console.log(arr);
    
  2. unshift() 在数组开头添加一个或者多个数组元素

    arr.unshift('A', 'B');
    console.log(arr);
    
  3. pop() 删除数组的最后一个元素

    console.log(arr.pop());
    console.log(arr);
    
  4. shift() 删除数组的第一个元素

    console.log(arr.shift());
    console.log(arr);
    
数组排序
方法名说明是否修改原数组
reverse()颠倒数组中元素的顺序该方法会改变原来数组 返回新数组
sort()对数组的元素进行排序该方法会改变原来数组 返回新数组
  1. 翻转数组

    var arr = [1, 25, 5];
    arr.reverse();
    console.log(arr);
    
  2. 数组排序(冒泡排序)

    var arr = [13, 4, 77, 1, 7];
    arr.sort(function(a,b) {return a - b; // 升序// return b - a; // 降序
    });
    console.log(arr);
    
数组索引方法
方法名说明返回值
indexOf()数组中查找给定元素的第一个索引如果存在返回索引号 如果不存在,则返回-1
lastIndexOf()在数组中的最后一个的索引如果存在返回索引号 如果不存在,则返回-1
数组转换为字符串
方法名说明返回值
toString()把数组转换成字符串,逗号分隔每一项返回一个字符串
join(‘分隔符’)方法用于把数组中的所有元素转换为一个字符串返回一个字符串

4、字符串对象

基本包装类型
  1. 把简单数据类型包装为复杂数据类型

    var temp = new String('Bob');
    
  2. 把临时变量的值给 str

    str = temp;
    
  3. 销毁这个临时变量

    temp = null;
    
字符串的不可变

字符串的值不可变,改变的实际上时地址变化,在内存中开辟了一个新的内存空间。

根据位置返回字符
方法名说明使用
charAt(index)返回指定位置的字符(index 字符串的索引号)str.charAt(0)
charCodeAt(index)获取指定位置处字符的ASCII码(index索引号)str.charCodeAt(0)
str[index]获取指定位置处字符HTML5, IE8+支持 和charAt()等效
字符串操作方法
方法名说明
concat(str1,str2,str3…)concat() 方法用于连接两个或多个字符串,等效于+,+更常用
substr(start, length)从start位置开始(索引号),length 取的个数
slice(start, end)从start位置开始,截取到end位置,end取不到
substring(start, end)从start位置开始,截取到end位置,end取不到 基本和slice相同,但是不接受负值

八、简单类型与复杂类型

1、简单类型与复杂类型

简单类型又叫做基本数据类型或者值类型 ,复杂类型又叫做引用类型

  • 值类型:简单数据类型/基本数据类型,在存储变量中存储的是值本身。
    string , number , boolean , undefined , null
  • 引用类型:复杂数据类型,在存储时变量中存储的仅仅是地址(引用)。
    通过 new 关键字创建的对象(系统对象、自定义对象),如 Object、Array、Date等

2、堆和栈

  1. 简单数据类型存放到栈里面
  2. 复杂数据类型存放到堆里面

JavaScript没有堆栈的概念

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/749173.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pytorch 入门基础知识二(Pytorch 02)

一 微积分 1.1 导数和微分 微分就是求导&#xff1a; %matplotlib inline import numpy as np from matplotlib_inline import backend_inline from d2l import torch as d2l def f(x):return 3 * x ** 2 - 4 * x 定义&#xff1a; 然后求 f(x) 在 x 1 时的导数&#xff…

请简述Redis集群的工作原理。Redis集群如何保证数据的一致性?Redis集群中,当某个节点出现故障时,如何处理?

请简述Redis集群的工作原理。 Redis集群的工作原理主要依赖于数据分片和主从复制机制&#xff0c;以实现横向扩展和高可用性。以下是Redis集群工作原理的简要概述&#xff1a; 数据分片&#xff1a; Redis集群将数据划分为16384个哈希槽&#xff08;hash slot&#xff09;。 …

接口测试之文件下载

在工作中对于下载接口&#xff0c;经常会有这样的疑问&#xff1a;这类接口一般功能比较稳定&#xff0c;但是又比较重要&#xff0c;需要占用回归测试时间&#xff0c;有没有可替代的方式&#xff1f; 答案肯定是有的&#xff0c;可以从接口测试/UI自动化测试介入&#xff0c…

Postman-Installation has failed

如图&#xff1a; 解决方法&#xff1a; 打开文件夹 Postman-win64-Setup 点击Postman.exe 即可

测试开发 - 面经 - 得物青训营

面前准备&#xff1a; 自我介绍 省略具体技术栈&#xff0c;侧重数据筛选部分以及数据可视化 实习经历简单表述 反问环节 对于测试开发的岗位认知还有些模糊&#xff0c;想问下这个岗位工作中的具体内容&#xff0c;以及常用的技术或者工具 想请教下对于测试开发岗未来的…

c语言的字符串函数详解

文章目录 前言一、strlen求字符串长度的函数二、字符串拷贝函数strcpy三、链接或追加字符串函数strcat四、字符串比较函数strcmp五、长度受限制字符函数六、找字符串2在字符串1中第一次出现的位置函数strstr七、字符串切割函数strtok&#xff08;可以切割分隔符&#xff09;八、…

【C语言】分支语句(逻辑运算符与关系运算符)

文章目录 **逻辑运算符(&&、||、!)**逻辑运算符特点短路短路-逻辑与短路-逻辑或 **关系运算符&#xff08;relational expression&#xff09;**运算操作符的结合律、运算符 **选择结构/分支结构****if 语句****复合句的if语句(if...else..语句)****不良风格的程序** *…

uniapp 之 实现商品详情的锚点跳转(类似京东商品详情-点击顶部按钮跳转的对应的页面的内容区域)

类似京东商品详情-点击顶部详情跳转到页面对应的详情区域&#xff0c;点击评价跳转到页面对应的评价区域等。 照例&#xff0c;先封装方法&#xff1a; 封装方法 util.js /*** 锚点跳转&#xff08;如&#xff1a;商品详情页面跳转&#xff09;* param {string} targetId 目…

sqllab第十八关通关笔记

知识点&#xff1a; UA注入 不进行url解析&#xff0c;不能使用 %20 编码等操作出现在User-agent字段中一般为insert语句 insert 表名(字段1&#xff0c;字段2&#xff0c;。。。) values(数据1&#xff0c;数据2&#xff0c;。。。) 通过admin admin进行登录发现页面打印出了…

【中等】保研/考研408机试-二叉树相关

目录 一、基本二叉树 1.1结构 1.2前序遍历&#xff08;注意三种遍历中Visit所在的位置&#xff09; 1.2中序遍历 1.3后序遍历 二、真题实战 2.1KY11 二叉树遍历&#xff08;清华大学复试上机题&#xff09;【较难】 2.2KY212 二叉树遍历二叉树遍历&#xff08;华中科技大…

通信信号处理中的调制识别技术及其基于C++ Qt的实现

在现代通信系统中,调制技术扮演着至关重要的角色。调制是将基带信号转换为适合在信道中传输的高频信号的过程。常见的模拟调制方式有幅度调制(AM)和频率调制(FM),数字调制方式有频移键控(FSK)和相移键控(PSK)。为了实现高效、可靠的通信,接收端必须能够准确识别发送端所采用的调…

详解命令docker run -d --name container_name -e TZ=Asia/Shanghai your_image

docker run 是Docker的主要命令&#xff0c;用于从镜像启动一个新的容器。下面详细解释并举例说明 -d, --name, -e TZ 参数的用法&#xff1a; -d 或 --detach&#xff1a; 这个标志告诉Docker以守护进程&#xff08;后台&#xff09;模式运行容器。这意味着当你执行 docker ru…

前端学习笔记|JavaScript基础

JS基础 数据类型 基于动力节点视频。 Number、String、Boolean、object 强制转换 Number 强转,boolean强转(undefined、null、NaN都是转成false)&#xff0c;String强转 myAge Number("123445"); Boolean(0); String(123);parseInt、parseFloat 遇到非数字&…

Java——网络编程

网络编程基础类 InetAddress类 java.net.InetAddress类用来封装计算机的IP地址和DNS(没有端口信息),它包括一个主机名和一个ip地址,是java对IP地址的高层表示。大多数其他网络类都要用到这个类&#xff0c;包括Sorket、ServerSocker、URL、DatagramSorket、DatagramPacket等常…

15.7k stars一个实用型OCR,支持80多种语言

一个实用型 OCR,支持 80 多种语言和所有流行的书写脚本&#xff0c;包括&#xff1a;拉丁文、中文、阿拉伯文、梵文、西里尔文等。 特点 支持本地或云/API部署 准确度提高到 99% 以上 完全可定制,支持 80 多种语言 支持表格识别 二维码/条码提取识别 GitHub数据 15.7k s…

LAMP下Moodle平台安装

目录 一、虚拟机安装 二、Linux使用ubuntu 三、设置管理员root的密码: 四、注销登录 五、用root账号重新登录 六、安装vmware tools 七、更新系统 八、允许SSH客户端登录 九、实体机中安装远程管理客户端 十、实体机安装文件传输工具 十一、使用Putty登录,安装插件…

学习总结2

第二周总结 一、总结贪吃蛇制作思路 1.绘制API&#xff0c;所以需要引入graphics.h这个图形界面库。 2.游戏规则 蛇是一节一节的&#xff0c;每吃掉一个事物都会长一节蛇吃食物需要移动&#xff0c;如果需要移动那么就会有坐标的变化。蛇没吃掉一个事物都会随机产生一个食物…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Column)

沿垂直方向布局的容器。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 可以包含子组件。 接口 Column(value?: {space?: string | number}) 从API version 9开始&#xff0c;该接口…

MySQL 中的自增ID及其应用场景

在MySQL中&#xff0c;自增ID主要体现在几种不同的场景下&#xff0c;每种自增ID都有其特定用途和行为特征&#xff1a; 1. Auto-Increment ID (PRIMARY KEY AUTO_INCREMENT) 场景&#xff1a;在创建表时&#xff0c;可以为某个整数字段设置AUTO_INCREMENT属性&#xff0c;生成…

LeetCode--58

58. 最后一个单词的长度 给你一个字符串 s&#xff0c;由若干单词组成&#xff0c;单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大 子字符串 。 示例 1&#xff1a; 输入&#xff1a;s "Hello W…