JavaEE day6 初识JavaScript

news2025/1/6 21:14:47

什么是JS

JS是通行在各种浏览器的一种语言,JAVA后端代码运行在服务器上,JS代码内容配合HTML,浏览器对JS代码进行解释运行,然后展现在浏览器上,web开发离不开JS。

一般步骤为:(index.html与script.js都是静态资源)

1.html内容传递到浏览器上被其分析解析,发现存在<script src="script.js"></script>

2.找到该关联资源script.js

3.运行该js代码,影响到html的最终结构

4.最终用户看到的效果=index,html中的内容+script.js代码修改的内容


如何在html中引入js

注意:脱离了html的js是没有用的。浏览器不会直接运行,直接在浏览器中输入js的url请求js资源,只能看见js的代码,并不能让其运行。

只有使用<script>标签才可以,其使用方法有两种

1.<script>直接写js代码</script>   js代码写在html文件中,不推荐

2.<script src=“script资源的URL”></script>   js与html文件分离,推荐使用

我们知道css的引入建议放在<head>中

而js的引入,也就是<script>标签,建议放在<body>中,并且出现在所有的元素后面(浏览器从上至下扫描,若<script>标签后还有其他标签可能导致js代码执行出错)若有多个<script>标签,按照执行的先后顺序,依次引入。


JS的打印

此处的打印不是打印到页面上,而是打印到开发者工具的控制台面板

首先JS和JAVA的区别有:

1.java所有执行的语句必须放在某个方法才可以,JS没有这个限制

2.java的第一条语句必须是main方法下的第一条语句,JS语句写出来就能执行,不需要main方法

console.log(....):意为 调用console对象的log方法,其中console为控制台对象,log为日志方法,将消息打印到控制台。console对象是JS天生提供好的对象。然后就可以在控制台上看到js的效果。

学习阶段可以在控制台上直接输入JS代码运行,输入后回车就可以,但是做项目得时候不可以,因为这种写法不会保存,关了浏览器就没了。

此处再提一个对象:window对象。

window:JS中唯一的全局对象,粗略的认为这个对象就是浏览器本身在JS中的化身。

例如window.console.log,因为是JS中唯一的全局对象,可以省略window:console.log


JS中的变量

和java的不同的地方:

1.JS的变量没有类型一说(数据是有类型的)比如java中int只能赋值为1、2、34这种而不能赋值为12.36,JS没有这种类型限制,但是数据是有类型的指的是,1、2是整型,12.36是浮点型。

使用:

在java中我们可以使用 int a = 2  指的是创建a对象类型为int赋值为2

JS中则是var a = xxx,a为变量名,但是JS不是赋值,而是创建a这个引用指向了xxx的对象,而后我们再使用a的时候直接可以a=“hello”指的是a引用指向“hello”这个对象      tips:JS中字符串单引号双引号都可以。


JS中的数据类型

1.数字类型(Number) 2 3 3e8 0x37

2.字符串类型   “xxxxx”   ‘xxxx’

3.布尔类型    true/false

4.特殊类型(错误类型)undefined未定义的/null空的    JS认为这两个类似


JS中相等的判断与 if  while

==比较相等(会进行隐式类型转换)

!=比较不等(会进行隐式类型转换)

===比较相等(不会进行隐式类型转换)

!==比较不等(不会进行隐式类型转换)

进行类型转换的意思是先把a数据和b数据的数据类型对齐也就是进行一次类型转换,然后再进行比较

而不转换的话,只要类型不同就直接判定false,类型相同才继续进行判断

例如:1==“1”为true              1==="1"为 false

java中的if....while....必须是布尔类型,因此 if  (1) while (1) 是错误的

但是js中 if  (1) while (1) 是可以的,0看作false,非0看作true  undefined/null看作true,“”看作false


JS中数组类型

JS中的数组内部结构类比为java中的顺序表,使用方法上类似数组,可以直接使用{下标]

java中的数组长度是固定的,顺序表的长度是可以变的。JS的数组长的是可变的。

var a = [] 空的数组

var a = [1,2,3,4]  四个元素的数组  

var a = [1,undefined,undefined,4]   四个元素的数组,其中两个类型为undefined

var a = [1,3,5,"hello","world"]  五个元素的数组,元素的类型可以是任意类型

var a = [1,3,5,["a","b","c"]]  四个元素的数组,其中第四个元素为另一个数组

如果我们使用下标来找元素。那么我们针对上面第二个数组

a[0] 就显示1 a[1]就显示2 a[2] 就显示3  a[3]就显示4,若是a[-1](下标不合法)则不会报错,会显示undefined!

如果我们在上面第二个数组中直接写出指向  : a[10] = 100,那么就会导致中间出现6个空元素,

[4] 到[9]都为空,那么他们的都被看作为undefined。

注意:不要给数组名直接赋值(此处其实是指向)!因为JS中引用也就是变量是没有类型的,上文提过,那么你给数组名称直接赋值实质上就是等于换了个指向。

例如var arr = ['小猪',‘小狗’]

arr = ‘小猫’,那此时arr指向就不为数组了,上面数组消失,arr指向字符串小猫。

数组方法

尾插push(...)

尾删pop(...)

头插unshift(...)

头删shift(...)

遍历数组的方法:

方法一:

for(var i = 0; i<var.length;i++){

        //i是下标

        //arr{i]是元素

}

方法二:

for(var i in arr){

        //i是下标

        //arr{i]是元素

}

方法三:

for(var e of arr){

        //e是元素,没有下标

}


JS中的函数

1.如何定义函数

function 函数名(a,b,c){

        语句

}

必须是function关键字开头,没有返回值类型(因为js本身变量就没有类型),且形参列表:没有变量类型也不用写var,上面直接写入元素a,b,c

语句:针对return:任何JS函数都肯定有一个返回值,哪怕没有写return,没写视为返回undefined,或者写return;没有表明return啥,也视为返回了undefined。

例如:

由于无论怎么样的都会有返回值,上图中全部都为调用该函数产生的返回值,而定义函数的时候返回值全部为undefined。

因为变量无类型,所以我们可以返回任何值,什么都行:

 2.函数的调用

函数名称(实参);

变量 = 函数名称(实参);

JS不要求形参和实参的个数完全对上。可以不一样(可以少也可以多),JS中是没有重载的概念的,因为形参无类型且个数无要求。

例如:

 那么

以上都可以调用该函数,最后一行多的4要用其他方式获取。 

重点:函数也是一种数据类型:其他JS数据类型能享受的,函数一样可以。时刻记住JS里的引用(变量)后=什么东西一定是指向而不是赋值,那么就很好理解!!

例如a = 1; a = ”hello“同样a = function(){}。

调用函数的时候我直接a()就可以了。

例如其他数据类型可以作为容器的元素,函数也可以。

数组 var a = [1,2] 同样也可以var a = [fuction(x){return x;}]

那么a[0]就代表这个函数,调用的时候,我们可以直接a[0](1)也可以var b指向a[0],再用b(1)调用。

例子:

 

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

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

相关文章

LinuxC—高级IO

高级IO 1 非阻塞IO/有限状态机编程 1.1 基本概念 定义 有限状态机(Finite State Machine) 缩写为 FSM&#xff0c;状态机有 3 个组成部分&#xff1a;状态、事件、动作。 状态&#xff1a;所有可能存在的状态。包括当前状态和条件满足后要迁移的状态。事件&#xff1a;也称为…

自动驾驶环境感知——视觉传感器技术

文章目录1. 摄像头的成像原理1.1 单目视觉传感器的硬件结构1.2 单目视觉的成像原理 –小孔成像模型1.3 单目视觉的成像原理 – 像素坐标系1.4 单目视觉三维坐标系转换 – 外参1.5 单目视觉的坐标系转换 – 从世界坐标点到像素坐标1.6 单目视觉的特性2. 视觉传感器的标定2.1 视觉…

CSS之精灵图

1. 精灵图 1.1 为什么需要精灵图 一个网页中往往会应用很多小的背景图像作为修饰&#xff0c;当网页中的图像过多时&#xff0c;服务器就会频繁地接收和发送请求图片&#xff0c;造成服务器请求压力过大&#xff0c;这将大大降低页面的加载速度。 为什么使用精灵图&#xff…

9、断点调试

文章目录9、断点调试9.1 为什么需要Debug9.2 Debug的步骤1 添加断点2 启动调试3 单步调试工具介绍9.3 多种Debug情况介绍1 行断点2 方法断点3 字段断点4 条件断点5 异常断点6 线程断点7 强制结束9.4 自定义调试数据视图9.5 常见问题【尚硅谷】idea实战教程-讲师&#xff1a;宋红…

Linux安装mysql--CentOS系统

Linux安装mysql 安装包&#xff1a; https://pan.baidu.com/s/10xvFpfl4nTktaEdhKbY3og 首先启动虚拟机&#xff0c;我是用FinalShell连接的 然后将下载的安装包上传至Linux系统中&#xff0c;直接rz回车就会跳出选择文件的窗口&#xff0c;选择需要上传的安装包即可等待上传…

计算机网络01_---软考高级系统架构师010

计算机网络知识点汇总: IPV4中有单播,组播,广播.IPV6没有广播 网络标准喝协议中要知道有IEEE802.3 以太网协议 局域网是以太网的一种 然后,IEEE802.11是无线局域网协议. TCP/IP协议族,这里,要知道从网络层开始,这里到传输层,然后传输层有个 TCP协议,这里TCP链接的时候有…

【沐风老师】3DMAX地板生成器插件FloorGenerator使用教程

FloorGenerator地板生成器插件&#xff0c;创建任何形状的地板几何图形&#xff0c;你可以完全控制从斜边到木板倾斜的所有参数。 伴随该地板的是”多重纹理贴图&#xff08;MultiTexture&#xff09;“插件&#xff0c;它使你能够将任意数量的位图随机指定给生成的地板。还提…

听障人士亲述:我们在VRChat用手语交流,成员规模5000人

如果你在B站上搜索VRChat&#xff0c;排在前面的热门视频几乎都是与老外聊天的内容。除了练习语言、交文化流外&#xff0c;你还能在VRChat上遇到不少哇哇乱叫的小孩。作为一款VR社交应用&#xff0c;除了有趣的小游戏外&#xff0c;说话聊天也是VRChat关键的玩法之一。而有这么…

离线ctr特征中心更新

3.8 离线ctr特征中心更新 学习目标 目标 了解特征服务中心的作用应用 无 3.8.1 特征服务中心 特征服务中心可以作为离线计算用户与文章的高级特征&#xff0c;充当着重要的角色。可以为程序提供快速的特征处理与特征结果&#xff0c;而且不仅仅提供给离线使用。还可以作为实时…

【My Electronic Notes系列——直流稳压电源】

目录 序言&#xff1a; &#x1f3c6;&#x1f3c6;人生在世&#xff0c;成功并非易事&#xff0c;他需要破茧而出的决心&#xff0c;他需要永不放弃的信念&#xff0c;他需要水滴石穿的坚持&#xff0c;他需要自强不息的勇气&#xff0c;他需要无畏无惧的凛然。要想成功&…

快速安装OpenShift在Ubuntu系统上并使用

目录 OpenShift简介&#xff1a; 服务器信息 安装Docker 安装OpenShift 访问Dashboard oc常用命令 附 OpenShift简介&#xff1a; OpenShift 是一个开源容器应用平台&#xff0c;由 Red Hat 开发。它建立在 Kubernetes 之上&#xff0c;并提供用于部署、扩展和管理容器…

【Linux】基础:线程的同步与互斥

【Linux】基础&#xff1a;线程的同步与互斥 摘要&#xff1a;本文主要介绍线程的同步与互斥方面的内容&#xff0c;分为理论与实现两部分完成。首先从整体上介绍线程同步与互斥相关概念&#xff0c;在理解概念后对两者分开介绍。在互斥方面&#xff0c;主要介绍内容为互斥量的…

LinuxC—线程

线程 1 线程的基本概念 什么是线程 进程其实是一个容器&#xff0c;当我们在编程的时候实际上是在以线程为单位进行编程&#xff0c;包括处理器的调度也是以线程为单位的&#xff0c;一个进程可以有多个线程&#xff0c;一个进程的多个线程共享相同的进程空间&#xff0c;所以…

设计模式 - 创建型模式_抽象工厂模式

文章目录创建型模式概述Case场景模拟工程模拟早期单机Redis的使用Bad ImplBetter Impl &#xff08;抽象⼯⼚模式重构代码&#xff09;定义适配接⼝实现集群适配器接口代理方式的抽象工厂类单元测试小结创建型模式 创建型模式提供创建对象的机制&#xff0c; 能够提升已有代码…

0、Spring工程构建Spring快速入门Spring配置文件详解注入Sprint相关API

1、Spring工程构建 创建工程项目目录文件夹 IDEA选择项目new一个module 配置案例 aop创建 创建并下载完毕后&#xff0c;点击file选择projert 选择按照的jdk版本 output选择当前目录&#xff0c; 点击右下方apply 选择facets&#xff0c;点击""号选择web 选择当前…

Pinia状态管理

1、Pinia和Vuex的对比 1.1、什么是Pinia呢&#xff1f; Pinia&#xff08;发音为/piːnjʌ/&#xff0c;如英语中的“peenya”&#xff09;是最接近pia&#xff08;西班牙语中的菠萝&#xff09;的词&#xff1b; Pinia开始于大概2019年&#xff0c;最初是作为一个实验为Vue…

Linux使用操作

文章目录各类小技巧&#xff08;快捷键&#xff09;软件安装systemctl软连接日期、时区IP地址、主机名IP地址和主机名虚拟机配置固定IP网络传输下载和网络请求端口进程管理主机状态环境变量上传、下载压缩、解压各类小技巧&#xff08;快捷键&#xff09; 强制停止 Linux某些程…

python语法 dot函数

dot是numpy里的函数&#xff0c;主要用于求向量相乘&#xff0c;矩阵乘法&#xff0c;矩阵与向量乘法一、一维向量相乘要求元素个数相同&#xff0c;相当于求内积&#xff0c;对应元素相乘再相加&#xff0c;“1*3 2*4 11”二、矩阵和矩阵相乘遵循矩阵乘法法则“左行 * 右列”…

高通平台开发系列讲解(WIFI篇)什么是WLAN无线局域网

文章目录 一、什么是WLAN1.1、WLAN发展史1.2、WLAN工作频段二、高通相关文件2.1、配置文件2.2、开机启动2.3、wpa_supplicant沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本文将基于高通平台介绍什么是无线局域网。 一、什么是WLAN 在WLAN领域被大规模推广和商用的是…

【编程入门】开源记事本(鸿蒙Java版)

背景 前面已输出多个系列&#xff1a; 《十余种编程语言做个计算器》 《十余种编程语言写2048小游戏》 《17种编程语言10种排序算法》 《十余种编程语言写博客系统》 《十余种编程语言写云笔记》 本系列对比云笔记&#xff0c;将更为简化&#xff0c;去掉了网络调用&#xff0…