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.rhkb.cn/news/277195.html

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

相关文章

深入了解 大语言模型(LLM)微调方法

引言 众所周知&#xff0c;大语言模型(LLM)正在飞速发展&#xff0c;各行业都有了自己的大模型。其中&#xff0c;大模型微调技术在此过程中起到了非常关键的作用&#xff0c;它提升了模型的生成效率和适应性&#xff0c;使其能够在多样化的应用场景中发挥更大的价值。 那么&…

pta上的几个例题

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话&#xff1a; 知不足而奋进&#xff0c;望远山而前行&am…

Git学习记录

目录 Git Git介绍 版本控制 版本控制工具 集中式版本控制工具 分布式版本控制工具 Git工作机制 ​编辑 Git和代码托管中心 Git安装 Git常用命令 设置用户签名 初始化本地库 查看本地库状态 添加到暂存区 提交到本地库 修改文件 历史版本 查看历史版本 版本…

【系统架构师】-第3章-信息系统基础知识

1、信息系统的基本功能 输入&#xff1a;决定于系统所要达到的目的及系统的能力和信息环境的许可存储&#xff1a;存储各种信息资料和数据的能力处理&#xff1a;数据处理工具&#xff0c;利用OLAP、DM&#xff08;数据挖掘&#xff09;技术输出&#xff1a;保证最终实现最佳的…

SQLiteC/C++接口详细介绍之sqlite3类(八)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;七&#xff09; 下一篇&#xff1a; SQLiteC/C接口详细介绍之sqlite3类&#xff08;八&#xff09;&#xff08;暂未发表&#xff09; 24.sqlite3_cr…

Python 导入Excel三维坐标数据 生成三维曲面地形图(面) 2、线条平滑曲面但有间隔

环境和包: 环境 python:python-3.12.0-amd64包: matplotlib 3.8.2 pandas 2.1.4 openpyxl 3.1.2 scipy 1.12.0 代码: import pandas as pd import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D from scipy.interpolate import griddata imp…

微服务:Bot代码执行

每次要多传一个bot_id 判网关的时候判127.0.0.1所以最好改localhost 创建SpringCloud的子项目 BotRunningSystem 在BotRunningSystem项目中添加依赖&#xff1a; joor-java-8 可动态编译Java代码 2. 修改前端&#xff0c;传入对Bot的选择操作 package com.kob.botrunningsy…

【QT】文件流操作(QTextStream/QDataStream)

文本流/数据流&#xff08;二级制格式&#xff09; 文本流 &#xff08;依赖平台&#xff0c;不同平台可能乱码&#xff09;涉及文件编码 #include <QTextStream>操作的都是基础数据类型&#xff1a;int float string //Image Qpoint QRect就不可以操作 需要下面的 …

瑞_23种设计模式_策略模式

文章目录 1 策略模式&#xff08;Strategy Pattern&#xff09;★1.1 介绍1.2 概述1.3 策略模式的结构1.4 策略模式的优缺点1.5 策略模式的使用场景 2 案例一2.1 需求2.2 代码实现 3 案例二3.1 需求3.2 代码实现 4 JDK源码解析&#xff08;Comparator&#xff09; &#x1f64a…

2核4G服务器够用吗?性能测评自己看

腾讯云轻量2核4G5M带宽服务器支持多少人在线访问&#xff1f;5M带宽下载速度峰值可达640KB/秒&#xff0c;阿腾云以搭建网站为例&#xff0c;假设优化后平均大小为60KB&#xff0c;则5M带宽可支撑10个用户同时在1秒内打开网站&#xff0c;并发数为10&#xff0c;经阿腾云测试&a…

电源常用电路:采样电路

在之前的帖子中,我们已经介绍了数字电源及其核心控制器PPEC。当然,数字电源除了包含电源拓扑电路以及数字控制核心外,还包括采样、驱动和通讯等外围电路。 本篇就先对电源的ADC采样原理和常用的采样调理电路进行介绍吧。 一、ADC采样原理 ADC(模数转换器)采样是将模拟信号…

如何使用Python进行数据可视化:Matplotlib和Seaborn指南【第123篇—Matplotlib和Seaborn指南】

如何使用Python进行数据可视化&#xff1a;Matplotlib和Seaborn指南 数据可视化是数据科学和分析中不可或缺的一部分&#xff0c;而Python中的Matplotlib和Seaborn库为用户提供了强大的工具来创建各种可视化图表。本文将介绍如何使用这两个库进行数据可视化&#xff0c;并提供…

12、MongoDB -- 通过 SpringBoot 整合 Spring Data MongoDB 操作 MongoDB 数据库(传统的同步API编程)

目录 通过 SpringBoot 整合 Spring Data MongoDB 操作 MongoDB 数据库&#xff08;传统的同步API编程&#xff09;演示前提&#xff1a;登录单机模式的 mongodb 服务器命令登录【test】数据库的 mongodb 客户端命令登录【admin】数据库的 mongodb 客户端命令 代码演示同步API编…

【海贼王的数据航海】排序——概念|直接插入排序|希尔排序

目录 1 -> 排序的概念及其运用 1.1 -> 排序的概念 1.2 -> 常见的排序算法 2 -> 插入排序 2.1 -> 基本思想 2.2 -> 直接插入排序 2.2.1 -> 代码实现 2.3 -> 希尔排序(缩小增量排序) 2.3.1 -> 代码实现 1 -> 排序的概念及其运用 1.1 -&g…

QT下跨平台库实现及移植经验分享

最近在移植公司一个QT桌面软件到android上&#xff0c;有一些公司自定义的库&#xff0c;用了很多windows的api&#xff0c;移植过程很是曲折&#xff0c;在此有一些感悟分享一下~ 一.自编写跨平台库 1.有时候为了程序给第三方用需要编译一些qt封装库&#xff0c;并可能跨平台…

学python新手如何安装pycharm;python小白如何安装pycharm

首先找到官网&#xff1a; Download PyCharm: The Python IDE for data science and web development by JetBrains 打开后选择下载&#xff0c;下图标红部分 点击exe程序&#xff0c;点击下一步&#xff01; 选择安装路径&#xff0c;下一步 弹出界面全选 选择默认 然后直接…

解锁数据潜力:OceanBase国产数据库学习不容错过的秘密!

介绍&#xff1a;OceanBase是一款由阿里巴巴和蚂蚁金服自主研发的通用分布式关系型数据库&#xff0c;它专为企业级应用而设计&#xff0c;具有金融级别的可靠性。以下是对OceanBase的详细介绍&#xff1a; 高可用性&#xff1a;OceanBase通过实现Paxos多数派协议和多副本特性&…

倒计时30,28天

1.队列Q (nowcoder.com) //1. #include<bits/stdc.h> using namespace std; #define int long long const int N2e56; const int inf0x3f3f3f3f; int dir[13]{0,31,28,31,30,31,30,31,31,30,31,30,31}; const double piacos(-1.0); int a[N],b[N]; bool cmp(int xx,int …

学点Java打小工_Day4_数组_冒泡排序

1 数组基本概念 程序算法数据结构 算法&#xff1a;解决程序的流程步骤 数据结构&#xff1a;将数据按照某种特定的结构来存储 设计良好的数据结构会导致良好的算法。 ArrayList、LinkedList 数组是最简单的数据结构。 数组&#xff1a;存放同一种类型数据的集合&#xff0c;在…

STM32基础--使用寄存器点亮流水灯

GPIO 简介 GPIO 是通用输入输出端口的简称&#xff0c;简单来说就是 STM32 可控制的引脚&#xff0c;STM32 芯片的 GPIO 引脚与外部设备连接起来&#xff0c;从而实现与外部通讯、控制以及数据采集的功能。STM32 芯片的 GPIO被分成很多组&#xff0c;每组有 16 个引脚&#xf…