Web前端-JavaScript

黑马程序员JavaWeb开发教程

文章目录

  • 一、js引入方式
    • 1、内部脚本
    • 2、外部脚本
  • 二、js基础语法
    • 1、书写语法
      • (1)基本语法
      • (2)输出语句
    • 2、变量
      • (1)变量
      • (2)注意事项
    • 3、数据类型、运算符、流程控制语句
      • (1)数据类型
      • (2)运算符
      • (3)流程控制语句
  • 三、js函数
      • (1)函数
  • 四、js对象
    • 1、Array
      • (1)数组的定义以及访问语法
      • (2)Array中的属性和方法
    • 2、String
      • (1)字符串的创建方式
    • 3、JSON
      • (1)JavaScript自定义对象
      • (2)JSON-介绍
      • (3)JSON-基础语法
    • 4、BOM
      • (1)BOM
      • (2)Window
      • (3)Location
    • 5、DOM
      • (1)DOM
      • (2)DOM操作小案例
  • 五、js事件监听
    • 1、事件监听
      • (1)概念
    • 2、JS事件监听
      • (1)事件绑定
      • (2)常见事件
      • (3)案例

  • JS介绍
  1. javaScript(简称JS)是一门跨平台、面向对象的脚本语言,是用来控制网页行为的,它能使网页可交互
  2. JavaScript和java是完全不同的语言,不论是概念还是设计,但是基础语法类似

一、js引入方式

1、内部脚本

  • 将JS代码定义在HTML页面中
  1. JavaScript 代码必须位于<scripy></script>标签之间

  2. 在HTML文档中可以在任意地方防止任意数量的<scripy></script>标签

  3. 一般会把脚本防止在<body>元素的底部这样可以改善显示速度

    在这里插入图片描述

2、外部脚本

  • 将JS代码定义在外部JS文件中,然后引入到HTML页面中
  1. 外部JS文件中,只包含JS代码,不包含<scripy></script>标签
  2. 在HTML文件中通过<scripy></script>标签来引入JS文件
  3. <scripy></script>标签不能自闭合
    在这里插入图片描述

二、js基础语法

1、书写语法

(1)基本语法

  • 区分大小写:与java一样,变量名、函数名以及其他的一切东西都是区分大小写的
  • 每行结尾的分号可有可无(建议写上)
  • 注释:
    • 单行注释:// 注释内容
    • 多行注释:/* 注释内容 */
  • 大括号表示代码块

(2)输出语句

  • 使用 window.alert() 写入警告框
  • 使用document.write() 写入HTML输出
  • 使用 console.log() 写入浏览器控制台输出
    在这里插入图片描述

2、变量

(1)变量

  • JavaScript中使用 var 关键字来声明变量

    • var 声明的变量作用域比较大,全局变量
    • var 声明的变量可以重复定义,后定义的会将前边定义的变量覆盖掉
  • JavaScript是一门弱类型语言,变量可以存放不同类型的值
    在这里插入图片描述

  • 变量名需要遵循如下规则

    • 组成字符可以使任何目、数字、下划线(_)、或者美元符号($)
    • 数字不能开头
    • 建议使用驼峰命名

(2)注意事项

  • ECMScript 6 新增了let关键字来定义变量。他的用法类似于 var ,但是所声明的变量只在let代码块内有效,且不允许重复声明。
  • 新增了 const 关键字,用来声明一个只读的常量,一旦声明,常量的值就不能改变

3、数据类型、运算符、流程控制语句

(1)数据类型

  • 原始类型
    • number:数字(整数、小数NaN)
    • string:字符串,单引号和双引号都可以
    • boolean:布尔
    • null:对象为空
    • undefined:当声明的变量未初始化时,该变量的默认值是undefined

(2)运算符

  1. 运算符
  • 算术运算符:+ , - , * , / , % , ++ , –
  • 赋值运算符:= , += , -= , *= , /= , %=
  • 比较运算符:> , < , >= , <= , != , == , ===
    • ==:会进行类型转换
    • ===:不会进行类型转换
  • 逻辑运算符:&& , || , !
  • 三元运算符:条件表达式 ?true_value : false_value
  1. 类型转换
  • 字符串类型转为数字 parseInt
    • 将字符串字面值转为数字,如果字面值不是数字,则转为 NaN
  • 其他类型转为boolean
    • Number:0 和 NaN 是 false,其余的都是 true
    • String:空为 false,其余的都是 true
    • Null和undefined:都是 false

(3)流程控制语句

  • if…else if …else…
  • switch
  • for
  • while
  • do…while
  • 语法与 java 当中一致

三、js函数

(1)函数

  • 介绍 :函数(方法)是被设计为执行特定人物的代码块

  • 定义:

    • JavaScript函数通过function关键字进行定义,语法为

      在这里插入图片描述

    • 第二种方式

      在这里插入图片描述

  • 注意:

    • 形式参数不需要类型,因为JS是弱类型语言
    • 返回值也不需要定义类型,可以在函数内部直接使用return返回即可
    • 调用:函数名(实际参数列表)
      在这里插入图片描述

四、js对象

1、Array

(1)数组的定义以及访问语法

  • JavaScript 中 Array 对象用于定义数组

  • 定义

    • 方式一

      在这里插入图片描述

    • 方式二

      在这里插入图片描述

  • 访问

    在这里插入图片描述

(2)Array中的属性和方法

  • 属性
    • length:社会或返回数组中元素的数量
  • 方法
    • forEach():遍历数组中每个有值的元素,并调用一次传入的函数

      在这里插入图片描述
      在这里插入图片描述

    • push():将新元素添加到数组的末尾,并返回新的长度

      • arr.push(3,4,5);
    • splice():从数组中删除元素

      • arr.splice(2,3);//从索引为2的位置开始删,一共删除3个元素

2、String

(1)字符串的创建方式

  • String字符串的创建方式有两种
			// 第一种方式var 变量名 = new String("...");var str = new String("Hello String");// 第二种方式var 变量名 = "...";var str = "HelloString";
  • 属性
    • length:字符串的长度
  • 方法
    • charAt():返回在指定位置的字符
    • indexOf():检索字符串
    • trim():去除字符串两边的空格,中间的不会去除
    • subString():提取字符串中两个指定的索引号之间的字符
      在这里插入图片描述

3、JSON

(1)JavaScript自定义对象

  • 定义格式
    在这里插入图片描述

  • 调用格式
    在这里插入图片描述

(2)JSON-介绍

  1. 概念:JavaScript Object Notation,JavaScript对象标记法
  2. JSON是通过JavaScript对象标记法书写的文本
  3. 由于其语法简单,层次结构鲜明,现多用于作为数据载体,在网络中进行数据传输
  4. 正确的JSON格式:key必须使用双引号
 {"name":"Tom","age":20,"gender":"male"}

(3)JSON-基础语法

  • 定义:
    在这里插入图片描述

  • value的数据类型为

    • 数字(整数或浮点数)
    • 字符串(在双引号中)
    • 逻辑值(true或者false)
    • 数组(在方括号中)
    • 对象(在花括号中)
    • null
  • JSON字符串转为JS对象
    在这里插入图片描述

  • JS对象转为JSON字符串
    在这里插入图片描述

4、BOM

(1)BOM

  • 概念:Browser Object Model 浏览器对象模型,允许JavaScript与浏览器对话,JavaScript将浏览器的各个组成部分封装为对象
  • 组成
    • Window:浏览器窗口对象
    • Navigator:浏览器对象
    • Screen:屏幕对象
    • History:历史记录对象
    • Locationn:地址栏对象

(2)Window

  • 介绍

    • 浏览器窗口对象
  • 获取

    • 直接使用window,其中window.可以省略
      在这里插入图片描述
  • 属性

    • history:对History对象的只读引用
    • location:用于窗口或者框架的Location对象
    • navigator:对Navigator对象的只读引用
  • 方法

    • alert():显示带有一段消息和一个确认按钮的警告框

    • confirm():显示带有一短消息以及确认按钮和取消按钮的对话框

      在这里插入图片描述

    • setInterval():按照指定的周期来调用函数或计算表达式

      在这里插入图片描述

    • setTimeout():在指定的毫秒数之后调用函数或计算表达式

      在这里插入图片描述

(3)Location

  • 介绍

    • 地址栏对象
  • 获取

    • 使用window.location获取,其中window.可以省略
      在这里插入图片描述
  • 属性

    • href :设置或返回完整的URL
      在这里插入图片描述

5、DOM

(1)DOM

  • 概念
    • Document Object Modeel,文档对象模型
  • 将标记语言的各个部分封装为对应的对象
    • Document:整个文档对象
    • Element:元素对象
    • Attribute:属性对象
    • Text:文本对象
    • Comment:注释对象
  • JavaScript 通过DOM,就能够对HTML进行操作
    • 改变HTML元素的内容
    • 改变HTML元素的样式CSS
    • 对HTML DOM 时间做出反应
    • 添加和删除HTML元素
  • DOM 是 W3C 的标准,定义了访问HTML和XML文档的保准,分为3个不同的部分
    1. Core DOM-所有文档类型的标准模型
    • Document:整个文档对象
    • Element:元素对象
    • Attribute:属性对象
    • Text:文本对象
    • Comment:注释对象
    1. XML DOM-XML 文档的标准模型
    1. HTML DOM -HTML文档的标准模型
    • Image:<img>
    • Button:<input type='button'>
      ###(2)获取HTML中的DOM对象
  • HTML的的Element对象可以通过Document对象获取,而Document对象是通过window对象获取的
  • Document对象中提供了以下获取Element元素的函数
    • 根据id属性值获取,返回单个Element对象

      在这里插入图片描述

    • 根据标签名称获取,返回Element对象数组

      在这里插入图片描述

    • 根据name属性值获取,返回Element对象数组

      在这里插入图片描述

    • 根据class 属性值获取,返回Element对象数组

      在这里插入图片描述

实例完整代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><img id ="h1" src="../img/off.gif" width="50px"><br><br><div class="cls">传智教育</div><br><div class="cls">黑马程序员</div><br><input type="checkbox" name="hobby">电影<input type="checkbox" name="hobby">旅游<input type="checkbox" name="hobby">游戏<script>// 1.获取 Element 元素 // 1.1 获取元素-根据 id 获取var img = document.getElementById("h1");alert(img);// 1.2 获取元素-根据标签获取var d = document.getElementsByTagName("div");for (let i = 0; i < d.length; i++) {alert(d[i]);}// 1.3 获取元素-根据 name 属性获取var names = document.getElementsByName("hobby");for (let i = 0; i < names.length; i++) {alert(names[i]);}// 1.4 获取元素-根据 class 属性获取var clsArray = document.getElementsByClassName("cls");for (let i = 0; i < clsArray.length; i++) {alert(clsArray[i]);}</script> <script>// 2、查询参考手册,属性、方法var divs = document.getElementsByTagName("div");var div1 = divs[0];//拿到第一个divdiv1.innerHTML = "传智教育666";</script>
</body>
</html>

结果示例

在这里插入图片描述

(2)DOM操作小案例

注意:可以在 https://www.w3school.com.cn/ 查找相关的操作DOM的属性和方法

  • 将灯泡点亮
  • 所有div标签的内容后边加上very good(红色字体)
  • 使所有的复选框呈现选中状态
    实例代码
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>DOM 练习</title>
</head><body><img id="h1" src="../img/off.gif" width="50px"><br><br><div class="cls">传智教育</div><br><div class="cls">黑马程序员</div><br><input type="checkbox" name="hobby">电影<input type="checkbox" name="hobby">旅游<input type="checkbox" name="hobby">游戏<script>// 1、点亮灯泡// 1.1 通过id属性拿到 img对象var img = document.getElementById("h1");// 1.2 操作元素的src属性img.src = "../img/on.gif";// 2、所有div标签的内容后边加上very good(红色字体)// 2.1 获得div标签var divs = document.getElementsByTagName("div");// 2.2 在div标签内容后边添加内容for (let i = 0; i < divs.length; i++) {const div = divs[i];div.innerHTML += "<font color='red'>  very good</font>";}// 3、使所有的复选框呈现选中状态// 3.1 根据name属性得到所有复选框var checks = document.getElementsByName("hobby");// 3.2 将复选框做成选中状态for (let i = 0; i < checks.length; i++) {checks[i].checked = true;// c.checked=true;}</script></body></html>

结果示例:

在这里插入图片描述

五、js事件监听

1、事件监听

(1)概念

  • 事件:HTML事件是发生在HTML元素上的“事情”。比如
    • 按钮被点击
    • 鼠标移动到元素上
    • 按下键盘按键
  • 事件监听
    • JavaScript 可以在时间被侦测到的时候执行代码

2、JS事件监听

(1)事件绑定

  • 方式一:通过HTML标签中的事件属性进行绑定

    在这里插入图片描述

  • 方式二:通过DOM元素属性绑定

    在这里插入图片描述

  • 完整示例代码

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>事件绑定</title>
</head><body><input type="button" id="btn1" value="事件绑定1" onclick="on()"><input type="button" id="btn2" value="事件绑定2"><!-- 方式一:通过HTML标签中的事件属性进行绑定 --><script>function on() {alert("事件绑定1被点击了");}</script><!-- 方式二:通过DOM元素属性绑定 --><script>document.getElementById("btn2").onclick = function () {alert("事件绑定2被点击了");}</script>
</body></html>

(2)常见事件

  • onclick:鼠标单击事件
  • onblur:元素失去焦点
  • onfocus:元素获得焦点
  • onload:某个页面或者图像被完成加载
  • onsubmit:当表单提交时出发改时间
  • onkeydown:某个键盘的键被按下
  • onmouseover:鼠标被移到某元素上
  • onmouseout:鼠标从某元素移开

注意:常见事件的使用方法在下个案例中有所提及

(3)案例

  1. 最初的图片是如下图:

在这里插入图片描述

  1. 案例要求如下
  • 1、 点击“点亮”按钮灯泡被点亮,点击“熄灭”按钮熄灭灯泡(即修改图片)
  • 2、输入框,鼠标聚焦之后展示小写,离焦之后展示大写
  • 3、点击“全选”按钮使所有复选框呈现被选中状态,点击“反选”按钮,使所有复选款呈现未被选中状态
  1. 最终呈现状态
    在这里插入图片描述

  2. 实例代码如下

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>练习 </title>
</head><body><img src="../img/off.gif" width="70px" id="img_id"><br><br><input type="button" value="点亮" onclick="on()"><input type="button" value="熄灭" onclick="off()"><br><br><input type="text" value="ITCAST" onfocus="fMouse()" onblur="bMouse()" id="text_value"><br><br><input type="checkbox" name="hobby">电影<input type="checkbox" name="hobby">游戏<input type="checkbox" name="hobby">旅游<br><br><input type="button" value="全选" onclick="on_select()"><input type="button" value="反选" onclick="on_unselect()"><br><br><script>//1、 点击“点亮”按钮灯泡被点亮,点击“熄灭”按钮熄灭灯泡(即修改图片)// 1.1 点亮,首先根据标签中的事件属性绑定事件,再通过document修改src属性function on() {document.getElementById("img_id").src = "../img/on.gif";}// 1.2 熄灭,同点亮function off() {document.getElementById("img_id").src = "../img/off.gif";}// 2、输入框,鼠标聚焦之后展示小写,离焦之后展示大写// 2.1 聚焦,onfocusfunction fMouse() {var text = document.getElementById("text_value");text.value = text.value.toLowerCase();}// 2.2 离焦,onblurfunction bMouse() {var text = document.getElementById("text_value");text.value = text.value.toUpperCase();}// 3、点击“全选”按钮使所有复选框呈现被选中状态,点击“反选”按钮,使所有复选款呈现未被选中状态// 3.1 全选function on_select() {var select = document.getElementsByName("hobby");for (let i = 0; i < select.length; i++) {select[i].checked = true;}}// 3.2 反选function on_unselect() {var unselect = document.getElementsByName("hobby");for (let i = 0; i < unselect.length; i++) {unselect[i].checked = false;}}</script>
</body></html>

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

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

相关文章

利驰软件亮相第二届全国先进技术成果转化大会

4月8日&#xff0c;第二届全国先进技术成果转化大会在苏开幕。省长许昆林出席大会开幕式并致辞。国家国防科工局局长张克俭&#xff0c;省委常委、苏州市委书记刘小涛分别致辞。 本次转化大会由江苏省国防科学技术工业办公室、苏州市人民政府、先进技术成果长三角转化中心主办…

暴力破解密码自动阻断

1 re模块 re 模块是 Python 中用于正则表达式操作的模块。正则表达式&#xff08;Regular Expression&#xff09;是一种强大的文本处理工具&#xff0c;它使用一种特殊的字符序列来表示字符串中的模式&#xff0c;并可以通过模式匹配、查找、替换等操作对文本进行高效处理。 …

AUTOCAD输出或打印PDF文件时,如何将图形居中且布满图纸?

AUTOCAD输出或打印PDF文件时,如何将图形居中且布满图纸? 如下图所示,我们打开一份DWG格式的图纸文件,然后点击上方的“打印“图标, 如下图所示, 打印机/绘图仪这里选择“DWG To PDF“; 图纸尺寸:这里以普通的A4纸为例进行说明; 打印比例选择“布满图纸“; 打印偏移…

Jmeter 简单的压力测试

今天我们一起利用Apache Jmeter&#xff08;一种接口测试工具&#xff09;来进行压力测试学习。压力测试主要目的是测试负载均衡的实现效果。 安装Jmeter这里就不做阐述了&#xff0c;上网下载个最新版就可以了&#xff0c;因为Jmeter是由JAVA语言开发的&#xff0c;所以安装之…

程序猿之路

我接触计算机算对自己来说是比较晚的了&#xff0c;上初中的时候就有微机课&#xff0c;但是在那个小县城&#xff0c;上课也只是3个人共用一个电脑&#xff0c;我初中整个过程只会开关机&#xff0c;哈哈&#xff0c;虽然学过word&#xff0c;但是无奈&#xff0c;我插不上手呀…

跟风Spring的context继承风格写的一个业务处理器,无聊

忽然记起spring的context的N重继承风格&#xff0c;一个抽象类实现一部份功能&#xff0c;想从那重改复写就从哪重开始。脑子一抽&#xff0c;也在业务代码里面玩了下。效果嘛。学得是有模有样&#xff0c;感觉就是越搞越复杂。有点过度设计了&#xff0c;折腾个啥呢。哈哈哈……

tcp的全连接队列和半连接队列满时,客户端再connect发生的情况

首先简单介绍下tcp的全连接队列(accept queue)和半连接队列(syn queue)&#xff0c; 1.客户端发起syn请求时&#xff0c;服务端收到该请求&#xff0c;将其放入到syn queue&#xff0c;然后回复acksyn给客户端。 2.客户端收到acksyn&#xff0c;再发送ack给服务端。 3. 服务端从…

通过adb 命令打印安装在第三方模拟器上的log

1&#xff0c;环境&#xff1a;Windows 11 &#xff0c;第三方模拟器 网易的MuMu 步骤&#xff1a; 1&#xff0c;打开cmd&#xff0c;输入 adb connect 172.0.0.1:7555 2&#xff0c;在cmd&#xff0c;再次输入adb logcat 回车

超详细的社交红人营销玩法来啦!点击查看↓天府锋巢直播产业基地重点服务优势

在刚刚过去的2023年 直播行业听到最多的词“红人营销” 可以算上其中之一 到底什么是红人营销&#xff1f; 红人营销如何做到声量和销量双增长&#xff1f; 企业如何产出 最真实有趣高效的营销内容&#xff1f; 天府锋巢为您解析基地 链主企业「无锋科技」提供的 重点优…

数据结构-上三角矩阵存储方式[0知识掌握]

目标&#xff1a;看完本文章你将会了解上三角矩阵的存储方式以及矩阵中数据的位置索引号如何求 难点&#xff1a;上三角矩阵的公式推导&#xff0c;上三角任意位置对应的存储位置。 一、准备知识 1.求和公式 前n项和&#xff1a;Sn n(a1an)/2 公差&#xff1a;d后项-前项…

winform 入门篇 复合控件

复合控件 自定义控件 除了框架自带的标准控件外&#xff0c;还可以自定义控件 有三种方式: 1 复合控件:将标准控件组合起来 class YourControl : UserControl{} 2 扩展控件:继承于标准控件 class YourControl : Button {} 3 自定义控件:完全地自定义一个控件 class YourCon…

MVVM、MVC、MVP的区别

MVC、MVP 和 MVVM 是三种常见的软件架构设计模式&#xff0c;主要通过分离关注点的方式来组织代码结构&#xff0c;优化开发效率。 在开发单页面应用时&#xff0c;往往一个路由页面对应了一个脚本文件&#xff0c;所有的页面逻辑都在一个脚本文件里。页面的渲染、数据的获取&a…