前端JS必用工具【js-tool-big-box】学习,检测当前是否为手机端浏览器,检测某元素是否处于当前可视范围内

这一小节,js-tool-big-box工具库又迎来了两个非常实用功能成员,分别是检测当前浏览器是否为手机端浏览器,还有检测某元素当前是否处于可视范围内

1 安装引入

通过npm安装,执行以下命令

npm i js-tool-big-box

这两个功能,工具库提供了一个叫browserBox的对象,所以代码中需要引入这个对象

import { browserBox } from 'js-tool-big-box';

2 检测当前是否为手机端浏览器 

这个功能还是很实用的,经常需要判断是否为手机端浏览器,做出与PC端不同的展示效果,判断示例代码如下:

const checkBrowser = browserBox.isMobileBrowser();
console.log('当前是手机端浏览器吗?', checkBrowser);

 上面两个图中,我们切换了浏览器的展示形式,分别以PC端和移动端两种形式做了效果展示。

使用方法总结:

方法名返回值入参
isMobileBrowsertrue或者false--

3 检测某元素是否处于可视范围内 

例如我们做懒加载的时候,就需要判断当前图片处于可视范围内,再开始加载图片,Vue2示例代码如下:

mounted() {window.addEventListener('scroll', this.handleScroll);},methods: {handleScroll() {const isInScreen = browserBox.isElementInViewport('.demo');console.log('.demo在可视区域内吗?', isInScreen);},go2Index() {this.$router.push("/index");},}

然后我们在HTML模板的地方做了很长的换行内容,意图就是为了有个浏览器下拉展示的过程,代码就不放了,基本就是上面30个br标签,下面30个br标签,中间一个 <div class="demo">被检测元素</div> 。下面我要开始下拉了啊,请注意!!!

使用方法总结:

方法名返回值入参

isElementInViewport

true或者false第一个参数必填,表示需要检测的元素,可以传入带有class的名字,如“.demo”,也可以是一个id的名字,如“#demo

4 小结 

 好啦,这就是这一小节添加的2个工具方法,js-tool-big-box的功能越来越丰富了,这都是小伙伴们的功劳,希望有更多的小伙伴提供一些实用的方法,加入到js-tool-big-box这个大家庭中来。

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

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

相关文章

@RequestParam和 @RequestBody有什么区别?

在Spring框架中&#xff0c;RequestParam和RequestBody是用于处理HTTP请求数据的两个不同注解&#xff0c;它们在使用场景和数据处理方式上有所区别。 RequestParam RequestParam用于将请求参数区数据绑定到控制器方法的参数上。它主要用于处理GET请求中的查询参数&#xff0…

跨域数据流动:数据提取过程中的治理与安全双轮驱动

跨域数据流动&#xff1a;数据提取过程中的治理与安全双轮驱动 随着信息技术的飞速发展&#xff0c;跨域数据流动已成为现代社会的常态。从医疗记录到金融交易&#xff0c;从社交媒体到企业运营&#xff0c;数据在各个领域之间频繁交换&#xff0c;为社会发展带来了极大的便利…

汽车电子笔记之-012:旋变工作原理及软解码硬解码

目录 1、旋变 1.1、激励的产生 1.2、旋变的标定 2、旋变解码 2.1、旋变硬解码 2.2、软解码 1、旋变 旋转变压器&#xff08;旋变&#xff09;&#xff0c;是电机控制中常用的一种位置传感器&#xff0c;用来反应电机的转子位置&#xff0c;提供给软件做电机控制等相关算法…

详细分析过电压保护器分类

按照结构特征部分 1、无间隙&#xff1a;功能部分为非线性氧化锌 电阻 片 2、串联间隙&#xff1a;功能部分为串联间隙及氧化锌电阻片 按照外形结构&#xff1a; F、复合绝缘外套 T、T型底座&#xff1a;相间距离&#xff1a;包括85、131、150、200、310、630等 W1、户外用&…

Spring之配置类源码深度解析

Spring之配置类源码深度解析 前言 Spring是一个非常流行的Java开发框架&#xff0c;它提供了很多便捷的功能和工具&#xff0c;使得Java开发变得更加高效和简单。其中&#xff0c;配置类是Spring框架中非常重要的一个概念&#xff0c;它可以用来定义Bean的创建和依赖关系&…

java基础之对线程的理解

目录 程序、进程、线程 什么是进程&#xff1f; 什么是线程 线程与进程的区别&#xff1f; 二、多线程 实现多线程方式一&#xff1a;继承Thread类 实现多线程方式二&#xff1a;实现Runnable接口 实现多线程方式三: 实现Callable接口 ​ 三种实现方式的对比 设置和获…

解释Python中的with语句在文件处理中的作用。

Python中的with语句提供了一种更加优雅和安全的方式来处理文件操作。它基于上下文管理器&#xff08;context manager&#xff09;的概念&#xff0c;能够自动管理资源的打开和关闭&#xff0c;即使在发生异常的情况下也能够保证文件被正确关闭。以下是with语句在文件处理中的作…

邦芒贴士:领导想让你主动辞职的3个表现

都说遇到一个好老板&#xff0c;比进入一个好公司还重要。好老板&#xff0c;可遇不可求&#xff1b;而遇不好的老板&#xff0c;不仅上班感到委屈&#xff0c;无奈的是想辞职经济又不允许。职场中充满着不公平的待遇&#xff0c;有克扣员工奖金的&#xff0c;有不发年终奖的&a…

Cesium 问题:使用 zoomTo 定位到模型上后展示太大了如何拉远相机

文章目录 问题分析问题 使用 zoomTo 定位到模型上后展示太大了如何拉远相机 分析 原that.map.zoomTo(tileset);现改为如果你觉得模型定位飞入后视角太小,可以尝试调整 new Cesium.HeadingPitchRange 中的参数来改变视角的范围。 new Cesium.HeadingPitchRange 接受三个参数…

Docker容器里面有什么东西?

2024年5月15日&#xff0c;周三下午 Docker 容器内部包含了一个运行的应用程序及其依赖环境。当你创建一个 Docker 容器时&#xff0c;你可以指定容器应该运行哪个镜像。这个镜像是由一系列层组成的&#xff0c;每一层包含了一些文件和目录。当你运行这个镜像时&#xff0c;Doc…

微前端架构 之 路由管理(二)

路由管理是一个核心部分&#xff0c;它负责处理多个子应用&#xff08;也称为微前端&#xff09;之间的页面跳转和导航。在微前端架构中&#xff0c;由于存在多个独立的子应用&#xff0c;因此需要一个全局的路由管理器来协调这些子应用的路由。 路由管理通常涉及以下几个方面&…

【WEEK12】 【DAY3】整合MyBatis框架【中文版】

2024.5.15 Wednesday 目录 13.整合MyBatis框架13.1.整合测试13.1.1.新建springboot-05-mybatis项目13.1.2.导入MyBatis需要的依赖13.1.3.配置数据库连接信息13.1.3.1.修改application.properties13.1.3.2.修改Springboot05MybatisApplicationTests.java并测试 13.1.4.新建pojo文…

InnoDB 事务处理机制

文章目录 前言1. 事务处理挑战1.1 事务机制处理的问题1.2 并发事务带来的问题 2. InnodDB 和 ACID 模型2.1 Innodb Buffer Pool2.2 Redo log2.3 Undo log2.4 应用案例 3. 隔离级别和锁机制3.1 事务隔离级别3.1.1 READ UNCOMMITTED3.1.2 READ COMMITTED3.1.3 REPEATABLE READ3.1…

SpringBoot应用

文章目录 第一章、SpringBoot基础内容一、Spring和SpringBoot1、Spring介绍2、SpringBoot介绍 二、SpringBoot2入门操作1、在线构建2、idea构建 三、浅谈自动装配的原理 第二章、SpringBoot核心功能一、配置文件1、配置文件介绍2、语法规则3、数据类型4、案例使用 二、WEB开发1…

vite+vue3 部署后,总是需要清除缓存的问题

1.每次部署后&#xff0c;需要清除缓存&#xff0c;才能看到最新代码&#xff0c;给打包文件加上hash就可以解决此问题。 vite.config.ts文件中加以下代码 build: {rollupOptions: {output: {entryFileNames: assets/[name].[hash].js,chunkFileNames: assets/[name].[hash].j…

如何管理测试用例?测试用例有什么管理工具?YesDev

3.1 测试用例 测试用例(Test Case) 是指对一项特定的软件产品进行测试任务的描述&#xff0c;体现测试方案、方法、技术和策略。其内容包括测试目标、测试环境、输入数据、测试步骤、预期结果等。简单地认为&#xff0c;测试用例是为某个特殊目标而编制的一组测试输入、执行条…

P1305 新二叉树

题目描述 输入一串二叉树&#xff0c;输出其前序遍历。 输入格式 第一行为二叉树的节点数 &#x1d45b;。(1≤&#x1d45b;≤26) 后面 &#x1d45b; 行&#xff0c;每一个字母为节点&#xff0c;后两个字母分别为其左右儿子。特别地&#xff0c;数据保证第一行读入的节点…

CPT7数据保存详细步骤

一、连接设备、打开NovAtelConnect 软件 (1)点击1,并在2中输入如下命令: LOG RANGEB ONTIME 1 // 输出原始数据记录在板卡LOG RAWEPHEMB ONTIME 1 // 输出 GPS 原始星历记录在板卡LOG bdsephemerisb ONTIME 1 // 输出

记使用pdf.js过程遇到的坑

最近项目中需要用到js库来渲染pdf文件&#xff0c;调研后发现无论是reach-pdf.js或者是svelte-pdf.js都是在pdf.js基础上做了些许精简&#xff0c;反而功能还不如原始的pdf.js来得全面。但是原始的库几乎没有像样的代码示例&#xff0c;而能搜索到的大多数代码不少都是十几年前…

在澳门写代码;技术入股2次融资被踢;现在只想做独立开发

本期我们邀请的程序员是Albert&#xff0c;先后在广州、澳门、珠海、香港工作过&#xff0c;打工上班、合伙创业、远程工作、独立开发&#xff0c;工作经历丰富&#xff0c;如果你想知道哪些程序员踩过的坑&#xff0c;请别错过他的故事。 广州&#xff1a;第一份工作2000块一…