Java Web——第二天

news2024/11/24 9:46:40

什么是JavaScript?

JavaScript(简称:JS) 是一门跨平台、面向对象的脚本语言。是用来控制网页行为的,它能使网页可交互

JavaScript和Java是完全不同的语言,不论是概念还是设计。但是基础语法类似

JavaScript在1995年由 Brendan Eich 发明,并于1997年成为 ECMA标准

ECMAScript 6(ES6)是最新的JavaScript版本(发布于2015年)

JavaScript引入方式

内部脚本:将JS代码定义在HTML页面中

JavaScript代码必须位于<script></script>标签之间

在HTML文档中,可以在任意地方,放置任意数量的<script>

一般会把脚本置于<body>元素的底部,可改善显示速度

外部脚本:将JS代码定义在外部JS文件中,然后入到HTML页面中

外部JS文件中,只包含JS代码,不包含<script>标签

<script>标签不能自闭合

JS基础语法

书写语法

区分大小写: 与Java 一样,变量名、函数名以及其他一切东西都是区分大小写的

每行结尾的分号可有可无

注释

单行注释://注释内容

多行注释:/*注释内容*/

大括号表示代码块

输出语句

使用 window.alert() 写入警告框使用

document.write() 写入 HTML 输出使用

console.log() 写入浏览器控制台

代码如下:

  <script> 
        // 浏览器弹出警告框
        window.alert('Hello js'); 

        // 写入HTML 在浏览器中显示
        document.write('Hello js');

        // 写入浏览器控制台
        console.log('Hello js');
    </script>

变量

JavaScript 中用 var 关键字 (variable 的缩写)来声明变量 (作用域大,全局变量,可重复定义

JavaScript 是一门弱类型语言,变量可以存放不同类型的值

变量名需要遵循如下规则

组成字符可以是任何字母、数字、下划线()或美元符号 (S)

数字不能开头

建议使用驼峰命名

注意事项

ECMAScript6 新增了 let 关键字来定义变量。它的用法类似于var,但是所声明的变量,只在let 关键字所在的代码块内有效,目不允许重复声明

ECMAScript6 新增了 const 关键字,用来声明一个只读的常量。一旦声明,常量的值就不能改变。

数据类型

javaScript中分为:原始类型 和引用类型

原始类型

number: 数字(整数、小数、NaN(Not a Number))

string: 字符串,单双引皆可

boolean:布尔。true,falsenull: 对象为空

undefined:当声明的变量未初始化时,该变量的默认值是 undefined

使用typeof 运算符可以获取数据类型

运算符

类型转换

流程控制语句

if...else if ...else...

switch

for

while

do ... while

js函数

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

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

function functionName(参数1,参数2..){
//要执行的代码
}

注意:

形式参数不需要类型。因为JavaScript是弱类型语言

返回值也不需要定义类型,可以在函数内部直接使用return返回即可

调用:函数名称(实际参数列表)

js对象

Array

JavaScript中Array对象用于定义数组

String

String字符串对象创建方式有两种

 

JavaScript自定义对象

定义格式: 

JSON-介绍

概念:JavaScript Object Notation,JavaScript对象标记法

JSON是通过JavaScript 对象标记法书写的文本 

由于其语法简单,层次结构鲜明,现多用于作为数据载体,在网络中进行数据传输

JSON-基础语法

BOM

概念:Browser Obiect Model 浏览器对象模型,允许JavaScript与浏览器对话,JavaScript 将浏览器的各个组成部分封装为对象

组成:

window:浏览器窗口对象

Navigator:浏览器对象

Screen:屏幕对象

History:历史记录对象

Location:地址栏对象

Window

介绍:浏览器窗口对象

获取: 直接使用window,其中 window.可以省略。
 

window.alert("Hello window");

alert("Hello window");

属性

history:对 History 对象的只读引用。请参阅 History 对象

location:用于窗口或框架的 Location 对象。请参阅 Location 对象

navigator:对 Navigator 对象的只读引用。请参阅 Navigator 对象

方法

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

//获取
window.alert("Hello BOM");
alert("Hello BOM window");

 

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

//方法
//confirm -对话框
var flag = confirm("您确认删除该记录吗?");
alert(flag);

点击确定返回true 取消则为false

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

//定时器 -setInterval -周期性的执行某一个函数
        var i = 0;
        setInterval(function(){
            i++;
            console.log("定时器执行了"+i+"次");
        },2000);

每两秒执行一次

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


        //定时器 -setTimeout -延迟指定时间执行一次
         setTimeout(function(){
            alert("3秒后执行");
         },3000)

Location

介绍:地址栏对象

获取:使用 window.location 获取,其中 window.可以省略

window.location.属性;

location.属性;

属性:

href: 设置或返回完整的URL。

location.href ="https://www.itcast.cn";
         //location
         alert(location.href);

         location.href = "https://www.baidu.com/";

点击确定后跳转到百度界面

DOM

概念: Document Object Model,文档对象模型将标记语言的各个组成部分封装为对应的

Document:整个文档对象

Element:元素对象

Attribute:属性对象

Text:文本对象

Comment:注释对象

JavaScript通过DOM,就能够对HTML进行操作

改变 HTML 元素的内容

改变HTML元素的样式(CSS)

对HTML DOM 事件作出反应

添加和删除HTML元素

DOM树

DOM是 W3C(万维网联盟)的标准,定义了访问HTML和XML文档的标准,分为3个不同的部分:

1.Core DOM- 所有文档类型的标准模型

Document:整个文档对象

Element:元素对象

Attribute:属性对象

Text:文本对象

Comment:注释对象

2.XMLDOM-XML文档的标准模型

3.HTML DOM-HTML 文档的标准模型3.

Image: <img>

Button : <input type='button'>

HTML中的Element对象可以通过Document对象获取,而Document对象是通过window对象获取

Document对象中提供了以下获取Element元素对象的函数:

1.根据id属性值获取,返回单个Element对象

var h1 = document.getElementById('h1');

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

var divs = document.getElementsByTagName('div');

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

var hobbys = document.getElementsBvName('hobby');

4.根据clas属性值获取,返回Element对象数组

var clss = document.getElementsByClassName('cls');
        //1.获取Element元素
        //1.1 获取元素 根据id获取
        var img = document.getElementById('h1');
        alert(img);

        //1.2 获取元素 根据标签获取 -div
        var div = document.getElementsByTagName('div');
        for (let i = 0; i < div.length; i++) {
            alert(div[i]);   
        }

        //1.3 获取元素 根据name属性获取
        var ins = document.getElementsByName("hobby");
        for (let i = 0; i < ins.length; i++) {
           alert(ins[i]);
        }

        //1.4 获取元素 根据class属性获取
        var divs = document.getElementsByClassName('cls');
        for (let i = 0; i < divs.length; i++) {
            alert(divs[i]);
        }
         //查询参考手册、属性、方法
        var divs = document.getElementsByClassName('cls');
        //获取第一个值 葫芦鸭
        var div1 =  divs[0];

        div1.innerHTML = "葫芦鸭666";

DOM案例

<!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/2.png"> <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">旅游
</body>
<script>
    //1.电量灯泡 : src属性值
    //获取元素对象
    var img = document.getElementById("h1");
    //调用元素对象中的属性或者方法控制元素
    img.src = "img/1.png";

    //2.将所有div标签的内容后面加上:very good(红色字体) <font color='red'></font>
    var divs = document.getElementsByTagName("div");
    for (let i = 0; i < divs.length; i++) {
        const div = divs[i];
        //在原有数据的基础上加上 very good 
        div.innerHTML += "<font color='red'>very good</font>" ;
        
    }
    //3.将所有复选框呈现选中状态
    var ins = document.getElementsByName("hobby");
    for (let i = 0; i < ins.length; i++) {
        const check = ins[i];
        check.checked = true; //选中状态
        
    }
    
</script>

</html>

事件监听

事件:HTML事件是发生在HTML元素上的“事情”。比如:

1. 按钮被点击

2. 鼠标移动到元素上

3. 按下键盘按键

事件监听:JavaScript可以在事件被侦测到时执行代码

事件绑定

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

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

<body>
    <input type="button" id="btn1" value="事件绑定1" onclick="on()">
    <input type="button" id="btn2" value="事件绑定2">
</body>
<script>
    //方式一:通过HTML标签中的事件属性进行绑定
    function on(){
        alert("按钮1被点击了");
    }
    //方式二:通过DOM元素属性绑定
    document.getElementById('btn2').onclick = function(){
        alert("按钮2被点击了");
    }
</script>

常见事件

<!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 onload="load()">
    <form action="" style="text-align: center;" onsubmit="subfn()">
        <input type="text" name="username" onblur="bfn()" onfocus="ffn ()" onkeydown="kfn()">
        
        <input id="b1" type="submit" value="提交">

        <input id="bl" type="button" value="单击事件" onclick="fnl()">
    </form>

        <br><br><br>
    
        <table width="800px" border="1" cellspacing="0" align="center" onmouseover="over()" onmouseout="out()">
            <tr>
                <th>学号</th>
                <th>姓名</th>
                <th>分数</th>
                <th>评语</th>
            </tr>
                <tr align="center">
                <td>001</td>
                <td>张三</td>
                <td>90</td>
                <td>很优秀</td>
            </tr>
                <tr align="center">
                <td>002</td>
                <td>李四</td>
                <td>92</td>
                <td>优秀</td>
            </tr>
            </table>
    
</body>
    <script>
        //onload:页面/元素加载完成后触发
        function load(){
            console.log("页面加载完成");
        }
        //onclick:鼠标点击事件
        function fnl(){
            console.log("我被点击了");
        }

        //onblur:失去焦点事件
        function bfn(){
            console.log("元素失去焦点");
        }

        //onfocus:元素获得事件
        function ffn(){
            console.log("元素获得焦点");
        }

        //onkeydown;某个键盘的键被按下
        function kfn(){
            console.log("键盘被按下了");
        }

        //onmouseover: 鼠标移到元素之上
        function over(){
            console.log("鼠标移入了");
        }

        //onmouseout:鼠标移除某元素
        function out(){
            console.log("鼠标移除出了");
        }

        //onsubmit:提交表单事件
        function subfn(){
            alert("表单被提交了");
        }
    </script>
</html>

事件监听案例

1.点击“点亮”按钮 点亮灯泡,点击“熄灭”按钮 熄灭灯泡
2.输入框鼠标聚焦后,展示小写;鼠标离焦后,展示大写
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>
</head>
<body>
    <img id="light" src="img/2.png"> <br>
    <input type="button" id="btn1" value="点亮" onclick="on()">
    <input type="button" id="btn2" value="熄灭" onclick="off()">
    <br> <br>

    <input type="text" id = "name" value="ITCAST" onfocus="lower()" onblur="upper()">
    <br> <br>

    <input type="checkbox" name="hobby">电影
    <input type="checkbox" name="hobby">游戏
    <input type="checkbox" name="hobby">旅游
    <br>

    <input type="button" value="全选" onclick="yes()">
    <input type="button" value="反选" onclick="no()">
</body>
    <script>
        //1. 点击 "点亮" 按钮,点亮灯泡; 点击 "熄灭” 按钮,熄灭灯泡; --onclick
        function on(){
            //获取img元素对象
            var img = document.getElementById("light");
            //设置src属性
            img.src = "img/1.png";
        }

        function off(){
            var img = document.getElementById("light");
            img.src = "img/2.png";
        }
        
        //2.输入框聚焦后,展示小写;输入框离焦后,展示大写; --onfocus onblur
        function lower(){ //小写
            //获取输入框元素对象
            var input = document.getElementById("name");
            //将值转为小写
            input.value = input.value.toLowerCase();
        }

        function upper(){ //大写
            //获取输入框元素对象
            var input = document.getElementById("name");
            //将值转为大写
            input.value = input.value.toUpperCase();

        }

        //3,点击"全选”按钮使所有的复选框呈现选中状态 ;点击“反选”按钮使所有的复选框呈现取消勾选的状态 --onclick
        function yes(){
            //获取所有复选框的元素对象
            var ins = document.getElementsByName("hobby");
            for (let i = 0; i < ins.length; i++) {
                const check = ins[i];
                //设置选中状态
                check.checked =  true;  
            }
        }

        function no(){
            var ins = document.getElementsByName("hobby");
            for (let i = 0; i < ins.length; i++) {
                const check = ins[i];
                check.checked =  false;  
            }
        }

    </script>

</html>

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

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

相关文章

8月6日Spring Boot学习笔记

MyBatis动态SQL 动态 SQL 大大减少了编写代码的工作量&#xff0c;更体现了 MyBatis 的灵活性、高度可配置性和可维护性。 if标签 <if test"判断条件">SQL语句</if> 当判断条件为 true 时&#xff0c;才会执行所包含的 SQL 语句。 choose、when和otherw…

我在杭州的Day30_进程间通信(IPC)——20240805

一、相关练习 1.使用有名管道实现&#xff0c;一个进程用于给另一个进程发消息&#xff0c;另一个进程收到消息后&#xff0c;展示到终端上&#xff0c;并且将消息保存到文件上一份 1.1> 01homework.c #include <myhead.h>int main(int argc, const char *argv[]) …

怎么实现外地分公司与总公司软件连接?

为了确保外地分公司能够顺利连接总公司的管理软件和财务软件&#xff0c;建立一个安全可靠的网络基础设施是必不可少的。首先&#xff0c;我们可以通过搭建虚拟专用网络来实现分公司与总公司内部网络的互联互通。虚拟专用网络不仅能够保障数据传输的安全性&#xff0c;还能提供…

SpringBoot简单项目(二维码扫描)

pom.xml中导入依赖 <!-- zxing --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.3.0</version></dependency><dependency><groupId>com.google.zxing</gro…

systemd-manage系统服务图形化管理工具使用教程

1. systemd-manage介绍 systemd-manage是一个开源的基于systemd服务管理的图形化工具&#xff0c;使用qt图形库进行开发&#xff0c;可以提供服务管理&#xff0c;用户会话&#xff0c;配置文件修改&#xff0c;日志查询&#xff0c;性能分析&#xff0c;进程管理等功能。图形…

【Pyautogui自动准备jupyter】附上报错合集,已解决

刚认识了pyautogui&#xff0c;浅浅写一段自动准备jupyter的程序 import pyautogui #import pyperclip import timedef open_jupyter():print(Opening jupyter...)time.sleep(1)try:location pyautogui.locateOnScreen(r"D:\STEFANOS\python\tools\auto\icons\jupyter…

SpringCloud入门简介

1. SpringCloud是什么 SpringCloud是微服务治理方案之一&#xff1b; SpringCloud与SSM框架和SpringBoot没什么关联 SSM&#xff1a;web应用的开发框架&#xff0c;包含视图层&#xff08;模型model视图view控制器controller&#xff09;&#xff0c;业务层&#xff0c;持久…

unity草体渲染方案 GPU Instaning

有一天看项目里的FrameDebug发现在森林系的场景里草体的drawcall差不多有100多 主要是因为灯光贴图&#xff0c;位置等不一样导致的打断合批&#xff0c;导致一个批次只能渲染10个左右的草体 之前有了解过unity有接口&#xff08;Graphics.DrawMeshInstanced&#xff09;可以把…

SpringBoot 框架学习笔记(七):Thymeleaf、拦截器 和 文件上传实现(解决了文件重名 和 按日期分目录存放问题)

1 Thymeleaf 1.1 基本介绍 &#xff08;1&#xff09;官方文档&#xff1a;Tutorial: Using Thymeleaf &#xff08;2&#xff09;Thymeleaf 是什么 Thymeleaf 是一个跟 Velocity、FreeMarker 类似的模板引擎&#xff0c;可完全替代 JSPThymeleaf 是一个 java 类库&#xf…

AnyGo(虚拟定位软件) for MacOS苹果电脑安装下载 支持最高系统 兼容M芯片

AnyGo for Mac是一款专为Mac用户设计的虚拟定位软件。它允许用户在Mac设备上模拟GPS位置&#xff0c;从而改变设备在各种基于位置的应用和服务中的显示位置。AnyGo提供了简单直观的操作界面&#xff0c;用户可以轻松地在地图上选择任意地点作为模拟位置&#xff0c;或者通过输入…

【平衡二叉树】数据结构—平衡二叉树

平衡二叉树&#xff08;Balanced Binary Tree&#xff09;是一种特殊的二叉树&#xff0c;它的左右子树的高度差不超过1&#xff0c;这样可以保证树的高度相对较低&#xff0c;从而使得查找、插入和删除操作的时间复杂度保持在 。 平衡二叉树的基本概念 1. 二叉树&#xff1a…

LeetCode 热题 HOT 100 (020/100)【宇宙最简单版】[创作中]

【链表】No. 0142 环形链表 II【中等】&#x1f449;力扣对应题目指路 希望对你有帮助呀&#xff01;&#xff01;&#x1f49c;&#x1f49c; 如有更好理解的思路&#xff0c;欢迎大家留言补充 ~ 一起加油叭 &#x1f4a6; 欢迎关注、订阅专栏 【力扣详解】谢谢你的支持&#…

C++ 简单学习

C简单编译 auto关键字 auto 关键字用于自动类型推导。它允许编译器自动推断变量的类型&#xff0c;使得代码更加简洁和易于编写&#xff0c;尤其是在处理复杂类型或模板编程时。使用 auto 可以避免编写冗长的类型声明&#xff0c;同时减少由于类型不匹配导致的编译错误 auto x…

学习vue3 三,组件基础,父子组件传值

组件基础 每一个.vue 文件都可以充当组件来使用 每一个组件都可以复用 父组件引入之后可以直接当标签使用 案例&#xff1a; App.vue <script setup lang"ts"> import BaseRefAndReactive from "./components/BaseRefAndReactive.vue";</sc…

Docker部署Node+Koa+TS+Mongo项目

Docker 简介 简而言之&#xff0c;Docker 容器轻量级、启动快、可移植&#xff0c;适合微服务架构。主要组件包括 Docker Engine、Docker 镜像、Docker 容器和 Docker Hub&#xff0c;它通过容器打包应用程序及其依赖项&#xff0c;使得应用在任何环境中都能一致运行。 这里不…

Selenium中send_keys上传图片方法以及可能失败的原因

Python Selenium是一个用于自动化浏览器操作的工具&#xff0c;可以用于模拟用户在浏览器中的各种操作。在使用Python Selenium进行自动化测试时&#xff0c;有时需要上传图片。下面是在这种情况下如何上传图片的步骤&#xff1a; 今天是主要说的是input标签&#xff0c;这种可…

基于R语言绘制GGE双标图3

参考资料&#xff1a; https://cran.r-project.org/web/packages/GGEBiplots/GGEBiplots.pdf GGE叠图法一分析品种环境互作模式的理想方法【作物学报】 GGE 双标图如何看&#xff1f;-CSDN博客 1、品种间两两比较 GGE 双标图可用于直接比较两个品种在各个试验点的表现&…

白银市场暴跌的技术分析与投资策略

一、白银市场暴跌与技术分析 周一&#xff08;8月5日&#xff09;&#xff0c;现货白银暴跌逾4.5%&#xff0c;并跌破关键的100日移动均线。FXStreet分析师Christian Borjon Valencia对银价技术走势进行了分析&#xff0c;指出银价前景转为看跌&#xff0c;技术面显示白银将进一…

探索Python并发的秘境:Greenlet库的奇幻之旅

文章目录 探索Python并发的秘境&#xff1a;Greenlet库的奇幻之旅背景&#xff1a;为何选择Greenlet&#xff1f;绿野仙踪&#xff1a;Greenlet是什么&#xff1f;安装&#xff1a;如何将Greenlet纳入囊中&#xff1f;功能探索&#xff1a;Greenlet的五大法宝场景应用&#xff…

【系统分析师】-综合知识-软件工程与项目管理

1、按照成本性态分类&#xff0c;可以分为固定成本、变动成本和混合成本。 &#xff08;1&#xff09;固定成本。管理人员的工资、办公费、固定资产折旧费、员工培训费、广告费、员工培训费、技术开发经费、办公场地及机器设备的折旧费、房屋及设备租金、管理人员的工资等。 …