JavaScript 基础(四)

devtools/2024/9/20 7:27:29/ 标签: javascript, 开发语言, ecmascript

五、DOM编程

1.常用事件

onload 页面加载后触发事件

onscroll 滚动时触发

onresize 尺寸变化时

onclick 鼠标点击

onmouseover 鼠标悬停

onmouseout 鼠标移出

onmousemove 鼠标移动,会触发多次

onfocus 对象获得光标(焦点)时(通常用于input标签)

onblur 对象失去光标(焦点)时

onselect 文本框里的文字被选中

onchange 文本框中的文字被改变时(通常用于下拉菜单)

onkeydown 按下键盘上的按钮

onkeyup 松开键盘上的按钮

onkeypress 上面两个共同

oncontextmenu 鼠标右击菜单

2.事件绑定

  • 侵入式绑定:将事件直接写在html标签中

div οnclick= 'add()' dianji div

function add(){}

  • 绑定式事件方式:通过DOM,使用js代码绑定

div /div

let divobj = document.getElementsByTagName('div')[0];

divobj.onclick = function(){}

  • 监听函数式事件方式:addEventListener()

addEventListener() 参数(事件名(没有前缀on),事件处理函数,布尔类型(一般为false)

true:进行事件捕获; false:不进行事件捕获;

div /div

let divobj = document.getElementsByTagName('div')[0];

divobj.addEventListener('click',function(){

},false);

3.表单元素事件

3.1表单元素事件

button onClick、onBlur、onFocus

checkbox onClick、onBlur、onFocus

FileUpload onClick、onBlur、onFocus

hidden none

password onBlur、onFocus、onSelect

radio onClick、onBlur、onFocus

reset onReset

select onBlur、onFocus、onChange

submit onSubmit

text onClick、onBlur、onFocus、onChange

textarea onClick、onBlur、onFocus、onChange

六、JSON轻量级数据交换格式

1.定义

JSON:JavaScript Obiect Notation

是一种轻量级的数据交换格式,易于编写和机器解析,采用完全独立于语言的数据交换语言

2.json数据格式

json数据属性以“键值对”的形式书写

let userArr = [

{userId:1, userName:'张三', userSex:'男'},

{userId:2, userName:'李四', userSex:'女'}

]

//获取json数组中的第一个对象

let user = userArr[0];

console.log(user.userId);

console.log(user.userName);

console.log(user.userSex);

//遍历json数组

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

console.log(userArr[i].userId,userArr[i].userName,userArr[i].userSex);

}

3.json与字符串之间的转换

let str = JSON.stringify(user); //将JSON对象转换成字符串

let str = JSON.stringify(userArr); //将JSON数组转换成字符串

let new_user = JSON.parse(str); //将字符串转换成JSON数组

七、Web存储

1、Web存储

客户端存储:Cookie,它是网站的身份证,是网站为了辨别用户身份,进行Session跟踪而存储在用户本地终端上的数据。Cookie每次都会跟随http请求发送到服务端,存在安全性问题

Cookie大小具有局限性,每个网站的Cookie个数也具有局限性,一般浏览器默认20个,而且会默认跟随http请求发送,即使不需要也会发送,会造成网络资源浪费。

对于Cookie的局限,Web Storage随之出现,它实现了支持大量数据存储,支持复杂的本地数据库,不会默认跟随http请求

2.Web Storage技术

2.1Session Storage

会话范围:从打开浏览器窗口到关闭

Session Storage 存储有效范围就是一个Session范围

  • setItem(): 该方法接受一个键和值作为参数,将会把键值对添加到存储中,如果键名存在,则更新其对应的值著作权归作者所有。

  • getItem():该方法接受一个键名作为参数,返回键名对应的值。

  • removeItem():该方法接受一个键名作为参数,并把该键名从存储中删除著作权归作者所有。

sessionStorage.setItem('user','张三)

let str = sessionStorage.getItem(user)

2.2Local Storage

Local Storage:永久存储,只要不主动移除,就一直在 localStorage.setItem('user','张三');

let str = localStorage.getItem('user');

2.3WebSQL(sql)

2.4indexedDB(no sql)

2.5Cookie

3.存储对象

SessionStorage 和LocalStorage中只能存储字符串数据。

如果需要存储对象,可以将对象转换为字符串进行存储,取出时,再将字符串转换为对象。

sessionStorage.setItem('user',JSON.stringify(user));

let obj = JSON.parse(sessionStorage.getItem('user'));

console.log(obj);


http://www.ppmy.cn/devtools/95675.html

相关文章

C语言 【自定义类型——结构体】(详细)

目录 1、结构体的定义 2、创建与初始化结构体变量 2.0 举例 2.1 结构体的特殊声明 2.1.0 匿名结构体 2.1.1 结构体的自引用 3、结构体内存对齐 3.0 为什么要内存对齐 3.1 对齐规则 3.2 如何修改默认对齐数 4、结构体传参 5、结构体中的位段使用 5.0 什么是位段&…

【研发日记】嵌入式处理器技能解锁(四)——TI C2000 DSP的Memory

文章目录 前言 背景介绍 Memory映射 RAM ROM 外设Register Memory分配 应用实例 总结 参考资料 前言 见《【研发日记】嵌入式处理器技能解锁(一)——多任务异步执行调度的三种方法》 见《【研发日记】嵌入式处理器技能解锁(二)——TI C2000 DSP的SCI(串口)通信》 见《…

编程修炼之Hibernate--- springboot启动初始化ddl过程

文章目录 跟踪Springboot整合hibernate的启动代码&#xff1a; 开始初始化 entityManagerFactory 创建方言 dialect 继续排查

EmguCV学习笔记 C# 2.5 Mat类、Matrix类和Image类的相互转换

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 EmguCV学习笔记目录 Vb.net EmguCV学习笔记目录 C# 笔者的博客网址&#xff1a;VB.Net-CSDN博客 教程相关说明以及如何获得pdf教…

从直播美颜工具到视频美颜SDK:实时美颜技术的实现与挑战

从最初的直播美颜工具到如今的高级视频美颜SDK&#xff0c;这一技术经历了快速的发展和演进。今天&#xff0c;笔者将讲解实时美颜技术的实现过程与其面临的挑战。 一、实时美颜技术的背景与需求 美颜技术不仅仅是对皮肤瑕疵的简单修饰&#xff0c;更涵盖了智能化的人脸识别、…

FreeRTOS信号量

文章目录 一、信号量的特性1、信号量的常规操作2、信号量跟队列的对比3、两种信号量的对比 二、信号量函数1、创建2、删除3、give/take 三、示例: 使用计数型信号量四、示例: 二进制信号量五、优先级反转 前面介绍的队列(queue)可以用于传输数据&#xff1a;在任务之间、任务和…

开源免费的表单收集系统TDuck

TDuck&#xff08;填鸭表单&#xff09;是一款开源免费的表单收集系统&#xff0c;它基于Apache 2.0协议开源&#xff0c;用户可以随时下载源码&#xff0c;自由修改和定制&#xff0c;也可以参与到项目的贡献和反馈中。TDuck表单系统不仅支持私有化部署&#xff0c;还提供了丰…

用后端实现一个简单的登录模块3 注册

该模块能做到的功能&#xff1a; 1阶&#xff1a;输入账号和密码&#xff0c;输入正确即可返回登录成功的信息&#xff0c;反之则登录失败 2阶&#xff1a;有简单的前端页面&#xff0c;有登录成功和失败的弹窗&#xff0c;还有登录成功的主页面 3阶&#xff1a;添加注册功能…

[Sqlserver][索引]SQL Server 索引概述

SQL Server 索引概述 索引简介 目的&#xff1a;提升SQL Server性能&#xff0c;加快查询速度&#xff0c;减少响应时间。限制&#xff1a;合理使用索引&#xff0c;避免过多索引影响数据更新操作和浪费硬盘空间。 索引分类 唯一索引 (UNIQUE)&#xff1a;确保索引值唯一。…

QT 数据导出到Excel

原创&#xff1a;QT 数据导出到Excel 在Qt自带的axcontainer模块中&#xff0c;我们可以使用QAxObject类来将数据保存到Excel中。Qt中将数据保存到Excel通常有两种方式&#xff1a;一种是以Excel格式导出&#xff0c;需要电脑上安装Office软件&#xff1b;另一种是以CSV格式导出…

React 学习——打包后,包体积可视化

1、安装插件 &#xff08; source-map-explorer &#xff09; npm i source-map-explorer 2、在配置文件package.json中加入 &#xff08; "analyze": "source-map-explorer build/static/js/*.js" &#xff09;&#xff0c;位置截图 "analyze&q…

力扣热题100_二分查找_35_搜索插入位置

文章目录 题目链接解题思路解题代码 题目链接 35. 搜索插入位置 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 …

聊聊JS中的WebSocket

你好&#xff0c;我是沐爸&#xff0c;欢迎点赞、收藏和关注。个人知乎 在JavaScript中&#xff0c;使用WebSocket非常简单直观。通过几行代码&#xff0c;你就可以轻松创建一个WebSocket连接&#xff0c;并监听来自服务器的消息。无论是开发实时聊天应用、在线游戏、实时数据分…

【项目】多设计模式下的同步异步日志系统(一)

继完成仿RabbitMq后&#xff0c;日志消息的不规范在&#xff0c;导致在调试的时候非常的麻烦。吸取了之前的经验后&#xff0c;以后要好好的打日志。博主在学习了设计模式后&#xff0c;做了这个日志系统项目。 总体来说&#xff0c;相对简易RabbitMq的实现更加简单。错误也明…

Containerd初体验

containerd概述 一、定义与功能 定义&#xff1a;Containerd是一个管理容器生命周期、镜像拉取和存储的工业级容器运行时。它提供了容器运行所需的核心功能&#xff0c;如镜像管理、容器生命周期管理、网络和存储管理等。功能&#xff1a; 管理容器的生命周期&#xff1a;从创…

【QT】基于UDP/TCP/串口 的Ymodom通讯协议客户端

【QT】基于UDP/TCP/串口的Ymodom通讯协议客户端 前言Ymodom实现QT实现开源库的二次开发-1开源库的二次开发-2 串口方式实现TCP方式实现UDP方式实现补充&#xff1a;文件读取补充&#xff1a;QT 封装成EXE 前言 Qt 运行环境 Desktop_Qt_5_11_2_MSVC2015_64bit &#xff0c;基于…

860.柠檬水找零

在柠檬水摊上&#xff0c;每一杯柠檬水的售价为 5 美元。顾客排队购买你的产品&#xff0c;&#xff08;按账单 bills 支付的顺序&#xff09;一次购买一杯。 每位顾客只买一杯柠檬水&#xff0c;然后向你付 5 美元、10 美元或 20 美元。你必须给每个顾客正确找零&#xff0c;…

【算法】蚁群算法

一、引言 蚁群算法&#xff08;Ant Colony Optimization, ACO&#xff09;是一种模拟蚂蚁觅食行为的启发式搜索算法。它由Marco Dorigo于1992年提出&#xff0c;适用于解决组合优化问题&#xff0c;如旅行商问题&#xff08;TSP&#xff09;、车辆路径问题&#xff08;VRP&…

Java面试--设计模式

设计模式 目录 设计模式1.单例模式&#xff1f;2.代理模式&#xff1f;3.策略模式&#xff1f;4.工厂模式&#xff1f; 1.单例模式&#xff1f; 单例模式是Java的一种设计思想&#xff0c;用此模式下&#xff0c;某个对象在jvm只允许有一个实例&#xff0c;防止这个对象多次引…

CogVideoX环境搭建推理测试

引子 智谱AI版Sora开源&#xff0c;首个可商用&#xff0c;18G显存即可运行。前文写了Open-Sora1.2的博文&#xff0c;感兴趣的童鞋请移步&#xff08;Open-Sora1.2环境搭建&推理测试_open sora 1.2-CSDN博客&#xff09;。对于这种占用资源少&#xff0c;且效果不错的多模…