0

0

jquery获取不可见元素的方法及应用

PHPz

PHPz

发布时间:2023-04-06 08:54:44

|

1716人浏览过

|

来源于php中文网

原创

随着网络技术的发展与普及,越来越多的网站应用开始采用动态页面技术,其中javascript框架jquery是应用得最为广泛的一种。在jquery中,获取元素是最基础的操作之一。但是有些节点元素由于一些样式设置或者位置限制,可能会让其变成不可见状态,而正是这些不可见节点元素,往往是我们在实际开发中需要对其进行操作的目标之一。那么如何使用jquery获取不可见元素呢?

一、不可见元素的类型分析

在jQuery中,常见的不可见元素有四种:display为none、visibility为hidden、元素宽度或高度为0、或者本身处于屏幕外(top或left过大或过小)。

1、 display为none

这部分元素在HTML页面中是存在的,但却并不会在页面中显示,也不占据页面布局空间。

例如下面HTML中的代码示例,虽然有两个div元素,但在页面中只有一个div是可见的:

这是一个可见的div元素

2、visibility为hidden

这部分元素跟display为none类型差不多,不过该元素不可见并且还会占据页面的布局空间。例如下面HTML中的代码示例,虽然有两个div元素,但在页面中两个div都占据了布局空间,只不过一个是可见的,一个是不可见的:

这是一个可见的div元素

3、元素宽度或高度为0

这种情况下元素占据的布局不会影响页面的布局,但因宽度或高度为0,所以我们无法直接找到和操作该元素。

例如下面HTML中的代码示例,虽然有三个div元素,但在页面中只有两个div是可见的,其它两个都是不可见的。其中“notVisibleDiv”元素的宽度和高度均为0,因而不可见且无法通过普通的选择器查找到:

这是一个可见的div元素
这是一个宽高都为0的不可见div元素
这是一个宽高都为0的、本身就在页面之外的不可见div元素

4、本身处于屏幕外(top或left过大或过小)

这些元素在页面中同样是存在的,但通常需要通过JavaScript代码才能找到并操作它们。

例如下面HTML中的代码示例,虽然有三个div元素,但在页面中只有一个div是可见的,另外两个都是不可见的。其中“leftSidedDiv”元素的left值太小,处于页面之外,而“rightSidedDiv”元素的left值太大,也出现类似问题:

这是一个可见的div元素
这是一个left值过小的不可见div元素
这是一个left值过大的不可见div元素

二、jQuery查找不可见元素的方法

由于有这些不可见的元素,所以在实际开发过程中,我们可能需要查找它们并进行某些操作,例如获取不可见元素的属性值、给不可见元素设置新样式等。

现在让我们来学习在jQuery中查找不可见元素的方法。根据上文分析,我们可以得到以下四种方法:

1、选择器

可以使用与查找可见元素相同的选择器来查找不可见元素。由于查找范围是整个文档,所以这种方法需要耗费一定的计算时间。但优点是代码简单易懂。

例如,我们想获取位于屏幕外的元素“leftSidedDiv”:

var notVisibleEle = $('#leftSidedDiv');

2、过滤选择器

Gridster.js多列网格式拖动布局插件
Gridster.js多列网格式拖动布局插件

网页中拖动 DIV 是很常见的操作,今天就分享给大家一个 jQuery 多列网格拖动布局插件,和其它的插件不太一样的地方在于你处理拖放的元素支持不同大小,并且支持多列的网格布局,它们会自动的根据位置自己排序和调整。非常适合你开发具有创意的应用。这个插件可以帮助你将任何的 HTML 元素转换为网格组件

下载

过滤器可以筛选出满足特定属性条件的元素。

例如,我们想获取position属性值为absolute的元素:

var notVisibleEle = $('div').filter(function() {
    return $(this).css('position') == 'absolute';
});

3、隐藏或显示不可见元素

这相当于把不可见元素挪到一个可控范围内,然后再获取属性值。

例如,我们想获取宽和高都为0的元素“notVisibleDiv”:

var hoverEleWidth = $('#notVisibleDiv').show().width();
var hoverEleHeight = $('#notVisibleDiv').show().height();
$('#notVisibleDiv').hide();

4、遍历文档树

jQuery可以通过遍历的方式来找到文档树中的不可见元素。这种方法可以获得更好的性能,因为只需要遍历部分文档树而非整个文档树。

例如,我们想获取所有屏幕外的元素:

$('#containerDiv').find('*').filter(function() {
    return $(this).position().left < 0 || $(this).position().left > $(document).width();
});

三、不可见元素的应用

了解了如何获取不可见元素,我们可以在实际开发过程中灵活应用。下面是一些具体的应用场景。

1、动态修改不可见元素属性

例如,我们在网页中被指定的div元素,原本是不可见状态,而当鼠标悬停在某个按钮上时,这个div需要显示,又当鼠标移开后,这个状态又要还原。


// 鼠标悬停时显示隐藏
$('#hoverBtn').hover(
    function() {
        $('#hoverDiv').show();
    },
    function() {
        $('#hoverDiv').hide();
    }
);

2、检测不可见元素大小

例如,我们需要获取目标节点的大小,并将其涵盖到浮层中

这是一个宽高都为0的不可见元素
// 获取目标节点大小
var targetWidth = $('.targetEle').show().width();
var targetHeight= $('.targetEle').show().height();

// 填充浮层中内容并显示
var popupContent = '目标节点的大小为宽:' + targetWidth + 'px,高:' + targetHeight + 'px';
$('.popupBox').html(popupContent).show();

$('.targetEle').hide();

3、获取不可见元素属性并进行操作

例如,当鼠标在某个导航上悬停时,能够获取到对应导航下的图片地址,然后通过Ajax请求,将图片展示在页面上。




// 鼠标悬停时操作
$('.navItem').hover(
    function() {
        var picUrl = $(this).data('pic-url');
        $.ajax({
            url: picUrl,
            success: function(data) {
                $('.imageContainer').html('jquery获取不可见元素的方法及应用');
            }
        });
    },
    function() {
        $('.imageContainer').empty();
    }
);

总结:

jQuery获取不可见元素涉及到了选择器、过滤选择器、隐藏或显示不可见元素和遍历文档树等多种方式。这些方法的灵活运用,在实际的开发中可以更好地满足我们的需求。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

40

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

50

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

12

2026.01.31

漫画防走失登陆入口大全
漫画防走失登陆入口大全

2026最新漫画防走失登录入口合集,汇总多个稳定可用网址,助你畅享高清无广告漫画阅读体验。阅读专题下面的文章了解更多详细内容。

13

2026.01.31

php多线程怎么实现
php多线程怎么实现

PHP本身不支持原生多线程,但可通过扩展如pthreads、Swoole或结合多进程、协程等方式实现并发处理。阅读专题下面的文章了解更多详细内容。

1

2026.01.31

php如何运行环境
php如何运行环境

本合集详细介绍PHP运行环境的搭建与配置方法,涵盖Windows、Linux及Mac系统下的安装步骤、常见问题及解决方案。阅读专题下面的文章了解更多详细内容。

0

2026.01.31

php环境变量如何设置
php环境变量如何设置

本合集详细讲解PHP环境变量的设置方法,涵盖Windows、Linux及常见服务器环境配置技巧,助你快速掌握环境变量的正确配置。阅读专题下面的文章了解更多详细内容。

0

2026.01.31

php图片如何上传
php图片如何上传

本合集涵盖PHP图片上传的核心方法、安全处理及常见问题解决方案,适合初学者与进阶开发者。阅读专题下面的文章了解更多详细内容。

2

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号