初识JS_API基础Day4——笔记整理+JS运行机制+1课后作业+蓝瘦香菇...

这篇博客介绍了JavaScript中的键盘事件,包括键盘事件和事件对象,详细讲解了BOM中的location对象及其属性和方法。同时,深入探讨了JavaScript的运行机制,解释了单线程、同步任务和异步任务的概念,并阐述了事件循环的工作原理。最后,还给出了一个关于自动更新时间的课后作业。
摘要由CSDN通过智能技术生成

一. 常用的键盘事件

1. 键盘事件

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

2. 键盘事件对象

在这里插入图片描述

二. BOM

1 . 什么是BOM
在这里插入图片描述

2 . window对象的常见事件
页面(窗口)加载事件(2种)
第1种
在这里插入图片描述
window.onload 是窗口 (页面)加载事件,当文档内容完全加载完成会触发该事件(包括图像、脚本文件、CSS 文件等), 就调用的处理函数。
第二种
在这里插入图片描述DOMContentLoaded 事件触发时,仅当DOM加载完成,不包括样式表,图片,flash等等。

​ IE9以上才支持!!!

3.调整窗口大小事件
在这里插入图片描述
注意:

①. 只要窗口大小发生像素变化,就会触发这个事件。

② . 常利用这个事件完成响应式布局window.innerWidth 当前屏幕的宽度


4 . 定时器(两种)

window 对象给我们提供了 2 个非常好用的方法-定时器。

  • setTimeout() 回调函数

  • setInterval()

在这里插入图片描述
5.停止定时器

 // 停止定时器
clearTimeout(timer);

6 . setInterval() 闹钟定时器

7 . location对象

URL常用属性:
在这里插入图片描述
location对象常见属性:
在这里插入图片描述

location对象的常见方法:
在这里插入图片描述

8 . history对象

在这里插入图片描述

9.navigator对象

​ navigator 对象包含有关浏览器的信息,它有很多属性,我们最常用的是 userAgent,该属性可以返回由客户机发送服务器的 user-agent 头部的值。

下面前端代码可以判断用户那个终端打开页面,实现跳转

if((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
    window.location.href = "";     //手机
 } else {
    window.location.href = "";     //电脑
 }

面试常问☆:
JS运行机制:

1 . JS 是单线程

单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。如果前一个任务耗时很长,后一个任务就不得不一直等着。
这样所导致的问题是: 如果 JS 执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的感觉。

2 . 同步任务和异步任务

​ 单线程导致的问题就是后面的任务等待前面任务完成,如果前面任务很耗时(比如读取网络数据),后面任务不得不一直等待!!

​ 为了解决这个问题,利用多核 CPU 的计算能力,HTML5 提出 Web Worker 标准,允许 JavaScript 脚本创建多个线程,但是子线程完全受主线程控制。于是,JS 中出现了同步任务异步任务

① 同步

​ 前一个任务结束后再执行后一个任务,程序的执行顺序与任务的排列顺序是一致的、同步的。比如做饭的同步做法:我们要烧水煮饭,等水开了(10分钟之后),再去切菜,炒菜。

② 异步

​ 你在做一件事情时,因为这件事情会花费很长时间,在做这件事的同时,你还可以去处理其他事情。比如做饭的异步做法,我们在烧水的同时,利用这10分钟,去切菜,炒菜。

JS中所有任务可以分成两种,一种是同步任务(synchronous),另一种是异步任务(asynchronous)。
同步任务指的是:
在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务;
异步任务指的是:
不进入主线程、而进入”任务队列”的任务,当主线程中的任务运行完了,才会从”任务队列”取出异步任务放入主线程执行。

在这里插入图片描述

3.JS执行机制(事件循环)
在这里插入图片描述

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


作业部分:
题目描述

页面上有一个电子时钟,显示当前的年月日,时分秒,要求自动变化,具体表现如下图:
在这里插入图片描述

1)要求双位显示,例如:九点九分九秒,显示为09:09:09

<body>
    <div></div>
    <script>
        var div = document.querySelector('div');
        getTimer()
        setInterval(getTimer, 1000);

        function getTimer() {
            var time = new Date();
            var year = time.getFullYear();
            var month = time.getMonth() + 1;
            var dates = time.getDate();
            var arr = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
            var day = time.getDay();
            var h = time.getHours();
            h = h < 10 ? '0' + h : h;
            var m = time.getMinutes();
            m = m < 10 ? '0' + m : m;
            var s = time.getSeconds();
            s = s < 10 ? '0' + s : s;
            div.innerHTML = year + '年' + month + '月' + dates + '日' + arr[day] + h + ':' + m + ':' + s;
        }
    </script>
</body>

分享
Day5笔记整理点击挑战

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值