百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

JavaScript中的常用事件,以及内置对象详解

myzbx 2025-01-10 15:41 50 浏览

今天是刘小爱自学Java的第81天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

学前端有一个非常权威的组织,也就是w3c,其有个专门的教程文档,特别的全面。

我研究了下其文档,发现竟然连Python的教程都有,Java倒是一直显示“即将上线”。

当然官方文档存在的最大意义在于遇到不懂的知识点了可以通过它找到对应的讲解。

至于学习最好还是跟着某些专业教程来,既能少走许多弯路,也能节省许多时间。

其中头条搜索有很多关于JavaScript的干货教程,专业又详细,点击下方卡片搜索“JavaScript”了解更多

一、js输出

这一块跟着文档学一学,对其有一定的了解,之后还是跟着教程走。

w3c网站将代码模板都给写好了,自己只需要做修改代码测试就可以了,十分方便。

1.innerHTML

document有一个方法getElementById(),见名知意,该方法是根据id获取对应的元素。

id是demo,那么获取id为demo的内容,上图中也就是1024。

但是为何输出又是“刘小爱”了呢?

原来还有个innerHTML,这是一个属性,相当于给id为“demo”的元素重新赋值了。

其中还有一个属性叫innerText,这个是只能修改元素内部的纯文本。

2.window.alert()

alert,警示的意思,也就是说调用alert方法,会弹出一个警示框来显示数据。

3console.log()

使用该方法可以将内容输出到浏览器控制台。

浏览器按F12即可打开浏览器控制台。

console,控制台的意思。

这个也就相当于IDEA中的控制台,只不过只是浏览器里面的,代码编写如下:

此外,昨天还学了一个专门输出的语句document.writeln(),就不再赘述了。

其实js中的所有知识点都可以在文档中学习。

但我这边主要还是学Java,不可能花大量的时间去学js,只学一个大概。

以后遇到问题,查文档能看懂即可。

二、js事件

事件是指浏览器或用户做的某些事情。

举几个例子:鼠标单击、双击某个按钮;键盘按着(不停地在输入);键盘弹起(输入结束)…

事件有好多个,暂且只学常用的几个。

①单击事件(全名函数注册)

onclick,即为单击的意思。

在input标签中有一个属性叫onclick,单击一下该按钮,会触发对应的事件。

也就是会调用onclick对应的那个函数,上图中就是click01函数。

所以点下按钮,click01函数执行,弹出警示框。

注意:函数名不能为click。

②双击事件(匿名函数注册)

ondblclick,它比onclick多一个dbl。dbl,double的简写,点两下单击,所以是双击。

这样记忆下来也就清晰好记多了。

其使用的是匿名注册,它的特点在于input标签中不用设置对应的函数名了。

而是用对应的id将该标签和匿名函数联系起来。

这样的好处在于耦合度低

如果出了什么意外,只需要删除匿名函数即可,对input标签本身不用修改。

但是使用匿名函数也会有一个问题:

一开始是将script标签放在了input标签下面,现在将其移动到head标签中做一个测试,会发现:

单击事件能够触发,但是双击事件不能触发

为什么会这样呢?我个人的理解是:

全名函数是直接在input标签(也就是HTML中)触发的事件;而匿名函数是在js中触发的事件。

这样匿名函数就会有一个执行顺序问题:

页面是从上到下执行的,当加载到js中双击事件的时候,对应的input标签都还没有加载呢。

那如何解决这个问题?

要么将script标签放在input标签后面,要么采用如下方法:

③页面加载事件

window.onload。根据其意思就能理解其表示的是网页加载完事件。

这是什么意思呢?

本来页面是从上到下依次执行的,当它加载到该事件的时候,相当于页面已经加载完了。

所以就算input标签在script标签的后面,也能触发事件。emm…暂且就是这样理解的。

三、js对象

学一学js中内置的几种常用对象

1数组对象

①关于数组遍历

在Java中数组直接打印是一串地址,但是在js中数组是可以直接打印的,数字之间用逗号隔开。

至于数组遍历,js和Java中一样,也是for循环遍历数组中的每一个元素,索引位从0开始。

②关于数组越界

在Java中,数组的长度确定后是不可变的,所以会出现越界问题。

但是在js中,数组的长度竟然是可变化的。

例子中直接给数组6索引位赋值,5索引位没有数字,默认为undefined(未定义数据)。

③关于数组方法

Java中的数组是没有特有方法的,只有继承自Object的方法。

但是js中的数组是有很多方法的,并且方法有点类似于Java中的集合:

  • concat:将两个数组拼接成一个新的数组。
  • reverse:将数组元素反转。
  • join:将对应元素和数组中的元素逐个拼接。
  • sort:将数组排序,直接排序默认是升序。
  • sort:使用比较器,a-b为升序,b-a为降序。

其中值得注意的是:反转、排序方法是对数组本身产生了修改。

而其它方法对数组本身没有影响,只是形成了一个新的数组。

2日期对象

①日期对象

直接打印是一串英文格式的日期。

②getTime()

也和Java中一样,获取系统当前时间的毫秒值。

③toLocaleString()

将时间格式转换成当前系统对应的本地格式。

在Java中,需要自定义格式,显得特别的麻烦,但是在js中直接调用该方法就可以了。

3全局对象

什么叫全局对象呢?

就是不用创建对象,直接可以使用该对象。

有点类似于Java中的静态方法,但是js中更简洁,连类名都没有的。

①parseInt()

在Java中Integer类就有一个静态方法parseInt(),作用就是将字符串转换成int类型。

但是在js中,并不是完全是这样。它的作用是:

  • 如果是字符串,会从首字母开始获取数字,一旦发现非数字字符,马上停止获取。
  • 如果是数字,遇到小数点就会停止获取内容。

②parseFloat()

该方法的作用和parseInt()的作用是大同小异的,区别在于是能转换成小数。

当带单位的数字(比如170cm)需要进行运算时,这两种方法会非常实用。

③isNaN()

该方法使用于对字符串的判断,见名知义,判断是否不是一个数字:

  • 如果字符串不是纯数字,返回值为true。
  • 如果字符串是纯数字,返回值为false。

①encode编码

可把字符串作为 URI 进行编码,让浏览器能看懂。

②decode解码

可以将编码过的URI进行解码。

编码后的URL我们是看不懂的,当浏览器上的参数被传入服务器时,又需要解码成我们能看得懂的。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 "小贱贱"韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...