JavaScript初级——基础知识
一、JS的HelloWord
1、JS的代码需要编写到script标签中

2、JS的执行是根据语句从上到下一次执行的。
二、JS的编写位置
1、可以将js代码编写到标签的onclick属性中,当我们点击按钮时,js代码才会执行。

2、可以将js代码写在超链接的href属性中,这样当点击超链接时,会执行js代码。

3、虽然可以写在标签的属性中,但是他们属于结构与行为耦合,不方便维护,不推荐使用。
4、可以将js代码编写到script标签中。

5、可以将js代码编写到外部的js文件中,然后通过script标签引入。
![]()
6、写到外部文件中可以在不同的浏览器中同时引用,也可以利用到浏览器的缓存机制,推荐使用这种方式。
7、script标签一旦用于引入外部文件了,就不能再编写代码了,即使编写了浏览器也会忽略。如果需要则可以再创建一个新的script标签用于编写内部代码。

三、基本语法
1、JS中的注释:注释中的内容不会被执行,但是可以在源代码中查看,要养成良好的编写注释的习惯,也可以通过注释来对代码进行一些简单的调适。
① /* */ 表示多行注释
② // 表示单行注释
2、JS中严格区分大小写。
3、JS中每一条语句以分号 ; 结尾。
——如果不写分号,浏览器会自动添加,但是会消耗一些系统资源,而且有些时候,浏览器会加错分号,所以在开发中分号必须写。
4、JS中会忽略多个空格和换行,所以我们可以利用空格和换行对代码进行格式化。

四、字面量和变量
1、字面量:一些不可改变的值,比如1 2 3 4 5 ······
字面量都是可以直接使用的,但是我们一般不会直接使用字面量。
2、变量:可以用来保存字面量,而且变量的值是可以任意改变的。更加方便我们使用,所以在开发中都是通过变量去保存一个字面量,而很少直接使用字面量。可以通过变量对字面量进行描述。
3、声明变量:在js中使用var关键字来声明一个变量。

声明和赋值也可以同时进行。

五、标识符
1、在JS中所有的可以由我们自主命名的都可以称为是标识符,例如:变量名、函数名、属性名都属于标识符。
2、命名一个标识符时需要遵守如下规则:
① 标识符中可以含有字母、数字、_ 、$。
② 标识符不能以数字开头。
③ 标识符不能是ES中的关键字和保留字。

④ 标识符一般都采用驼峰命名法
——首字母小写,每个单词的开头字母大写,其余小写。【如:helloWorld 、 xxxYyyZzz】

3、JS底层保存标识符时实际上是采用的Unicode编码,所以理论上讲,所有的utf-8中含有的内容都可以作为标识符(可以用中文但不建议)。
六、数据类型
1、数据类型指的就是字面量的类型。
2、在JS中一共有六种数据类型:
String 字符串
Number 数值
Boolean 布尔值
Null 空值
Undefined 未定义
Object 对象
其中 String Number Boolean Null Undefined 属于基本数据类型,而 Object 属于引用数据类型。
3、String 字符串
① 在JS中字符串需要使用引号引起来,使用双引号或者单引号都可以。

② 引号不能嵌套,双引号里面不能放双引号,单引号里面不能放单引号。正确使用如下:

③ 在字符串中我们可以使用 \ 作为转义字符,当表示一些特殊符号时可以使用 \ 进行转义。
\" 表示 "
\' 表示 '
\n 表示换行
\t 表示制表符,相当于一个Tab
\\ 表示 \

④ alert(“str”); 表示输出字面量 字符串str
alert(str); 表示输出变量str
4、Number 数值
① 在JS中左右的数值都是Number类型,包括整数和浮点数(小数)。

② var a = 123; 表示数字123
var a = “123”; 表示字符串123
③ 可以使用一个运算符 typeof 来检查一个变量的类型。
语法: typeof 变量
检查字符串时会返回 string; 检查数值时会返回 number 。
![]()
④ JS中可以表示的数字的最大值—— Number.MAX_VALUE 【表示数值为:1.7976931348623157e+308】
⑤ 如果使用 Number 表示的数字超过了最大值,则会返回一个 Infinity 表示正无穷;同理,-Infinity表示负无穷。使用typeof检查Infinity也会返回Number。
⑥ NaN是一个特殊的数字,表示 Not A Number(非数值);使用typeof检查NaN也会返回Number。
⑦ Number.MIN_VALUE 大于0的最小值 【表示数值为:5e-324】
⑧ 在JS中整数的运算基本可以保证精确,如果使用JS 进行浮点数运算,可能得到一个不精确的结果,所以千万不要使用JS进行对精确度要求比较高的运算。
5、Boolean 布尔值
① 布尔值只有两个【true 表示真; false 表示假】,主要用来做逻辑判断。
② 使用 typeof 检查一个布尔值时,会返回 boolean 。
6、Null 空值
① Null类型的值只有一个,就是null。
② null这个值专门用来表示一个为空的对象。
③ 使用 typeof 检查一个null值时,会返回 object 。
7、Undifined 未定义
① Undifined类型的值只有一个,就是undefind
② 当声明一个变量时,但是并不给变量赋值时,它的值就是undefined。
③ 使用 typeof 检查一个 undefined 时也会返回 undefined 。

七、强制类型转换
1、指将一个数据类型强制转换为其他的数据类型。
2、类型转换主要指,将其他的数据类型转换为 String 、 Number 、 Boolean 。
3、将其他的数据类型转换为String
-
方式一:
① 调用被转换数据类型的 toString() 方法。 【调用xxx的yyy()方法就是 xxx.yyy()】
② 该方法不会影响到原变量,它会将转换的结果返回。
③ 但是要注意: null 和 undefined 这两个值没有 toString ()方法;如果调用他们的方法会报错。
-
方式二:
① 调用 String() 函数,并将被转换的数据作为参数传递给函数。
② 使用 String() 函数做强制类型转换时,对于 Number 和 Boolean 实际上就是调用的 toString()方法;但是对于 null 和 undefined ,就不会调用 toString()方法,它会将 null 【字面量】直接转换为 “null”【字符串】,将 undefined 【字面量】直接转换为“undefined”【字符串】。

4、强制转换为Number
-
方式一:
使用 Number() 函数。
① 字符串转换为数字 —— 如果是纯数字的字符串,则直接将其转换为数字;
—— 如果字符串中有非数字的内容,则转换为NaN;
—— 如果字符串是一个空串或者是一个全是空格的字符串,则转换为0。
② 布尔值转换为数字 —— true 转换为1
—— false 转换为0
③ Null 转换为数字 0
④ undefined 转换为数字 NaN
⑤ 调用 parseInt()函数将含有数字和非数字的数字部分转换为Number
-
方式二:
① 这种方式专门用来对付字符串
② parseInt() 把一个字符串转换为一个整数,可以将一个字符串中的有效的整数内容取出来,然后转换为Number。
parseFloat() 把一个字符串转换为一个浮点数。作用和 parseInt()类似,不同的是它可以获得有效的小数。
③ 如果对非 String 使用 parseInt() 或 parseFloat(),它会先将其转换为 String 然后再操作。

5、强制转换为Boolean
-
方式一:
① 使用 Boolean() 函数
② 数字转换为布尔值:除了 0 和 NaN ,其余都是true。
③ 字符串转换为布尔值:除了空串,其余都是true。
④ null 和 undefined 都会转换为false。
⑤ 对象也会转换为 true 。

-
方式二:
隐式类型转换:为任意的数据类型做两次非运算,即可将其转换为布尔值

八、其他进制的数字
1、在js中,如果需要表示16进制的数字,则需要以 0x 开头。
2、如果表示8进制的数字,需要以 0 开头。
3、如果表示2进制的数字,需要以0b开头,但不是所有的浏览器都支持。
4、像“070”这种字符串,有些浏览器会当成8进制,有些会当成10进制进行解析,可以再parseInt()中传递一个第二个参数,来指定数字的进制。

本文的分享就到这里,下一节继续分享关于JavaScript初级知识的学习。
相关文章:
JavaScript初级——基础知识
一、JS的HelloWord 1、JS的代码需要编写到script标签中 2、JS的执行是根据语句从上到下一次执行的。 二、JS的编写位置 1、可以将js代码编写到标签的onclick属性中,当我们点击按钮时,js代码才会执行。 2、可以将js代码写在超链接的href属性中࿰…...
0817(持久层框架:JDBC,MyBatis)
三层架构(表现层,业务层,持久层) java中框架的概述(表现层、业务层、持久层的关系)_控制层业务层持久层的关系-CSDN博客 框架:框架一般处在低层应用平台(如J2EE)和高层…...
在亚马逊云科技上安全、合规地创建AI大模型训练基础设施并开发AI应用服务
项目简介: 小李哥将继续每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿AI技术解决方案,帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS AI最佳实践,并应用到自己的日常工作里。 本次介绍的是如何在亚马逊云科技利用Servi…...
无人机模拟训练室技术详解
无人机模拟训练室作为现代无人机技术培训的重要组成部分,集成了高精度模拟技术、先进的数据处理能力及高度交互的操作界面,为无人机操作员提供了一个安全、高效、接近实战的训练环境。以下是对无人机模拟训练室技术的详细解析,涵盖系统基础概…...
【Spring框架】
一、引言二、Spring核心概念三、Spring入门示例四、进一步了解Spring的依赖注入五、Spring的面向切面编程(AOP)六、总结 一、引言 Spring框架自2003年发布以来,凭借其轻量级、易于扩展的特性,在Java企业级应用开发领域得到了广泛…...
uniapp 日常业务 随便写写 源码
现成的组件 直接用 <template><view style"margin: 10rpx;"><view class"tea-header"><text class"tea-title">礼尚往来</text><view class"tea-view-all"><text>查看全部</text>&l…...
【软件测试】单元测试20套练习题
(一)概述 使用Java语言编写应用程序,设计测试数据,完成指定要求的白盒测试,对测试数据及相应测试结果进行界面截图,将代码以及相关截图粘贴到白盒测试报告中。 (二)题目要求...
8.16 day bug
bug1 题目没看仔细 额外知识 在 Bash shell 中,! 符号用于历史扩展功能。当你在命令行中输入 ! 后跟一些文本时,Bash 会尝试从你的命令历史中查找与该文本相匹配的命令。这是一种快速重用之前执行过的命令的方法。 如何使用历史扩展 基本用法: !strin…...
《Nginx核心技术》第11章:实现MySQL数据库的负载均衡
作者:冰河 星球:http://m6z.cn/6aeFbs 博客:https://binghe.gitcode.host 文章汇总:https://binghe.gitcode.host/md/all/all.html 星球项目地址:https://binghe.gitcode.host/md/zsxq/introduce.html 沉淀,…...
使用 Gnosis Safe 创建多签名钱包
创建多签名钱包可以通过多个步骤完成,具体取决于你使用的平台或工具。下面我将介绍使用 Gnosis Safe 创建多签名钱包的过程,因为它是目前以太坊生态中最受欢迎且功能强大的多签名钱包之一。 目录 使用 Gnosis Safe 创建多签名钱包1. 准备工作2. 访问 Gnosis Safe3. 创建多签名…...
LeetCode 算法:前 K 个高频元素 c++
原题链接🔗:前 K 个高频元素 难度:中等⭐️⭐️ 题目 给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 示例 1: 输入: nums [1,1,1,2,2,3], k 2 输出: [1,2] 示例 2…...
MySQL的SQL语句更新某个字段的值在原来值的基础上随机增加100~600
要在 MySQL 中更新某个字段的值,使其在原有值的基础上随机增加一个 100 到 600 之间的值,你可以使用 RAND() 函数来生成随机数,并结合其他 SQL 函数进行计算。以下是一个 SQL 更新语句的示例: UPDATE your_table_name SET your…...
LeetCode --- 410周赛
题目列表 3248. 矩阵中的蛇 3249. 统计好节点的数目 3250. 单调数组对的数目 I 3251. 单调数组对的数目 II 一、矩阵中的蛇 只要按照题目要求模拟即可,代码如下 class Solution { public:int finalPositionOfSnake(int n, vector<string>& commands…...
最佳的iPhone解锁软件和应用程序
在探讨最佳的iPhone解锁软件和应用程序时,我们需要考虑多个方面,包括软件的解锁能力、易用性、安全性、兼容性以及用户评价等。以下是对当前市场上几款优秀iPhone解锁软件和应用程序的详细分析,旨在为用户提供全面而深入的指导。 一、奇客iO…...
初等函数和它的表达式
常量函数,幂函数,指数函数,对数函数,三角函数和反三角函数成为基本初等函数。基本初等函数经过有限四则运算和符合运算得到的函数称为初等函数。 1. 常量函数 表达式: (其中 c 是常数)参数的意…...
Android 12系统源码_多屏幕(二)模拟辅助设备功能开关实现原理
前言 上一篇我们通过为Android系统开启模拟辅助设备功能开关,最终实现了将一个Activity显示到多个屏幕的效果。 本篇文章我们具体来分析一下当我们开启模拟辅助设备功能开关的时候,Android系统做了什么哪些操作。 一、模拟辅助设备功能开关应用位置 …...
【Go语言初探】(二)、项目文件结构和GOPATH设置
一、go语言项目文件结构 由go/bin、go/src和go/pkg三个子文件夹组成,见下图: 实际项目: 二、gopath路径变量设置 在项目中创建main.go文件后,IDE会提示设置GOPATH路径: 点击“configure GOPATH”,设置GOP…...
三种简单排序:插入排序、冒泡排序与选择排序 【算法 05】
三种简单排序:插入排序、冒泡排序与选择排序 在编程中,排序算法是基础且重要的知识点。虽然在实际开发中,我们可能会直接使用标准库中的排序函数(如C的std::sort),但了解并实现这些基础排序算法对于理解算法…...
Python -- GUI图形界面编程—GUI编程实例 博主也在持续学习中[ 持续更新中!!! 欢迎白嫖 也求粉啊啊啊~ ]
本文介绍了GUI的图形界面编程(相关视频是哔站上的应该搜这个题目就能找到),文章还是很基础的,反正我是小白从0开始,主要的结构tinkter库、重要组件简介(这个不用死记硬背 用的时候再说)、Label&…...
Vue2和Vue3中的diff算法
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、diff算法是什么?二、vue2中的diff算法三、vue3中的diff算法总结 前言 一、diff算法是什么? diff算法很早就存在了,一开…...
几何完备扩散模型GCDM:从理论突破到SBDD实战评测与部署指南
1. 几何完备扩散模型GCDM的核心突破 第一次看到GCDM论文时,我被它解决3D分子生成痛点的思路惊艳到了。传统方法就像用2D积木搭3D建筑——EDM等模型依赖的EGNN网络只能处理距离信息,而GCDM引入的GCPNET架构彻底改变了游戏规则。这个改进相当于给模型装上了…...
CK3M多轴运动控制器实战:EtherCAT总线伺服系统从零配置全解析
1. CK3M控制器与EtherCAT系统初识 第一次接触CK3M多轴运动控制器时,我完全被它强大的功能震撼到了。这款控制器就像工业自动化领域的"大脑",能够同时协调多个伺服电机精准运动。而EtherCAT总线技术则是连接这个大脑与各个执行机构(…...
Nomic-Embed-Text-V2-MoE实战:构建智能文档检索系统与MySQL集成
Nomic-Embed-Text-V2-MoE实战:构建智能文档检索系统与MySQL集成 1. 引言 想象一下,你所在的公司有成千上万份产品手册、技术文档和合同文件,它们散落在各个文件夹里,格式五花八门。当你想找一份关于“如何解决产品X在低温环境下…...
从ResNet到mHC:DeepSeek重构残差连接,额外开销仅6.7%,附复现代码
2015年,由微软亚洲研究院的何恺明团队提出ResNet,ResNet引入残差连接的概念,用以解决深层神经网络训练中的梯度消失/爆炸和网络退化问题,使得训练极深的网络成为可能。 ��1��&#x…...
当Transformer遇上魔改鲸鱼:时序预测还能这么玩
GSWOA-Transformer多变量时序预测 Matlab代码 基于改进鲸鱼优化算法(GSWOA)优化Transformer的数据回归预测(可以更换为分类/单变量时序预测/回归,前私我),Matlab代码,可直接运行,适合小白新手 程序已经调试好,无需更改…...
FPGA仿真提速秘籍:手把手教你配置VSCode,一键运行iverilog编译+GTKWave看波形
FPGA仿真效率革命:VSCodeiverilogGTKWave全自动化工作流实战 在数字电路设计领域,仿真验证环节往往占据整个开发周期60%以上的时间。传统基于命令行的仿真流程需要工程师反复输入冗长指令,手动切换多个工具界面,这种低效的工作模…...
保姆级教程:用星图AI平台训练PETRV2-BEV模型,新手也能玩转自动驾驶
保姆级教程:用星图AI平台训练PETRV2-BEV模型,新手也能玩转自动驾驶 1. 前言:为什么你需要这篇教程? 如果你对自动驾驶技术感兴趣,想亲手训练一个能“看懂”周围环境的AI模型,但又被复杂的代码、昂贵的硬件…...
逆向分析实战:从IDA反编译看bjdctf_2020_babystack的栈溢出漏洞成因与利用
逆向工程实战:bjdctf_2020_babystack栈溢出漏洞的深度解析 在二进制安全领域,栈溢出漏洞始终是攻防对抗的经典课题。今天我们将以bjdctf_2020_babystack这道CTF题目为案例,通过IDA Pro的静态分析视角,完整还原从漏洞发现到利用的…...
PolSARPro软件安装全攻略:从下载到处理Sentinel-1A数据的保姆级教程
PolSARPro软件安装全攻略:从下载到处理Sentinel-1A数据的保姆级教程 在遥感数据处理领域,PolSARPro无疑是一颗璀璨的明珠。这款由法国雷恩第一大学开发的极化合成孔径雷达处理软件,已经成为科研人员和学生处理Sentinel-1A等卫星数据的首选工具…...
国风美学模型与卷积神经网络(CNN)结合:风格迁移与质量增强
国风美学模型与卷积神经网络(CNN)结合:风格迁移与质量增强 最近在尝试用AI生成国风图像时,我遇到了两个挺实际的问题。一个是生成的图片虽然意境不错,但风格上总觉得少了点传统水墨丹青的韵味;另一个是&am…...
