Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 619|回复: 0

JS无法获取display为none的隐藏元素的宽度和高度的解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-28 02:52:52 | 显示全部楼层 |阅读模式

    在实际开发中会遇到确实需要获取隐藏元素的宽高,这儿所说的隐藏元素是display为none的元素。

    可使用jQuery Actual Plugin插件来完成,其源码如下:

    ;( function ( $ ){
      $.fn.addBack = $.fn.addBack || $.fn.andSelf;
    
      $.fn.extend({
    
        actual : function ( method, options ){
          // check if the jQuery method exist
          if( !this[ method ]){
            throw '$.actual => The jQuery method "' + method + '" you called does not exist';
          }
    
          var defaults = {
            absolute      : false,
            clone         : false,
            includeMargin : false,
            display       : 'block'
          };
    
          var configs = $.extend( defaults, options );
    
          var $target = this.eq( 0 );
          var fix, restore;
    
          if( configs.clone === true ){
            fix = function (){
              var style = 'position: absolute !important; top: -1000 !important; ';
    
              // this is useful with css3pie
              $target = $target.
                clone().
                attr( 'style', style ).
                appendTo( 'body' );
            };
    
            restore = function (){
              // remove DOM element after getting the width
              $target.remove();
            };
          }else{
            var tmp   = [];
            var style = '';
            var $hidden;
    
            fix = function (){
              // get all hidden parents
              $hidden = $target.parents().addBack().filter( ':hidden' );
              style   += 'visibility: hidden !important; display: ' + configs.display + ' !important; ';
    
              if( configs.absolute === true ) style += 'position: absolute !important; ';
    
              // save the origin style props
              // set the hidden el css to be got the actual value later
              $hidden.each( function (){
                // Save original style. If no style was set, attr() returns undefined
                var $this     = $( this );
                var thisStyle = $this.attr( 'style' );
    
                tmp.push( thisStyle );
                // Retain as much of the original style as possible, if there is one
                $this.attr( 'style', thisStyle ? thisStyle + ';' + style : style );
              });
            };
    
            restore = function (){
              // restore origin style values
              $hidden.each( function ( i ){
                var $this = $( this );
                var _tmp  = tmp[ i ];
    
                if( _tmp === undefined ){
                  $this.removeAttr( 'style' );
                }else{
                  $this.attr( 'style', _tmp );
                }
              });
            };
          }
    
          fix();
          // get the actual value with user specific methed
          // it can be 'width', 'height', 'outerWidth', 'innerWidth'... etc
          // configs.includeMargin only works for 'outerWidth' and 'outerHeight'
          var actual = /(outer)/.test( method ) ?
            $target[ method ]( configs.includeMargin ) :
            $target[ method ]();
    
          restore();
          // IMPORTANT, this plugin only return the value of the first element
          return actual;
        }
      });
    })(jQuery);

    当然如果要支持模块化开发,直接使用官网下载的文件即可,源码也贴上:

    ;( function ( factory ) {
    if ( typeof define === 'function' && define.amd ) {
        // AMD. Register module depending on jQuery using requirejs define.
        define( ['jquery'], factory );
    } else {
        // No AMD.
        factory( jQuery );
    }
    }( function ( $ ){
      $.fn.addBack = $.fn.addBack || $.fn.andSelf;
    
      $.fn.extend({
    
        actual : function ( method, options ){
          // check if the jQuery method exist
          if( !this[ method ]){
            throw '$.actual => The jQuery method "' + method + '" you called does not exist';
          }
    
          var defaults = {
            absolute      : false,
            clone         : false,
            includeMargin : false,
            display       : 'block'
          };
    
          var configs = $.extend( defaults, options );
    
          var $target = this.eq( 0 );
          var fix, restore;
    
          if( configs.clone === true ){
            fix = function (){
              var style = 'position: absolute !important; top: -1000 !important; ';
    
              // this is useful with css3pie
              $target = $target.
                clone().
                attr( 'style', style ).
                appendTo( 'body' );
            };
    
            restore = function (){
              // remove DOM element after getting the width
              $target.remove();
            };
          }else{
            var tmp   = [];
            var style = '';
            var $hidden;
    
            fix = function (){
              // get all hidden parents
              $hidden = $target.parents().addBack().filter( ':hidden' );
              style   += 'visibility: hidden !important; display: ' + configs.display + ' !important; ';
    
              if( configs.absolute === true ) style += 'position: absolute !important; ';
    
              // save the origin style props
              // set the hidden el css to be got the actual value later
              $hidden.each( function (){
                // Save original style. If no style was set, attr() returns undefined
                var $this     = $( this );
                var thisStyle = $this.attr( 'style' );
    
                tmp.push( thisStyle );
                // Retain as much of the original style as possible, if there is one
                $this.attr( 'style', thisStyle ? thisStyle + ';' + style : style );
              });
            };
    
            restore = function (){
              // restore origin style values
              $hidden.each( function ( i ){
                var $this = $( this );
                var _tmp  = tmp[ i ];
    
                if( _tmp === undefined ){
                  $this.removeAttr( 'style' );
                }else{
                  $this.attr( 'style', _tmp );
                }
              });
            };
          }
    
          fix();
          // get the actual value with user specific methed
          // it can be 'width', 'height', 'outerWidth', 'innerWidth'... etc
          // configs.includeMargin only works for 'outerWidth' and 'outerHeight'
          var actual = /(outer)/.test( method ) ?
            $target[ method ]( configs.includeMargin ) :
            $target[ method ]();
    
          restore();
          // IMPORTANT, this plugin only return the value of the first element
          return actual;
        }
      });
    }));

    代码实例:

    //get hidden element actual width
    $('.hidden').actual('width');
    
    //get hidden element actual innerWidth
    $('.hidden').actual('innerWidth');
    
    //get hidden element actual outerWidth
    $('.hidden').actual('outerWidth');
    
    //get hidden element actual outerWidth and set the `includeMargin` argument
    $('.hidden').actual('outerWidth',{includeMargin:true});
    
    //get hidden element actual height
    $('.hidden').actual('height');
    
    //get hidden element actual innerHeight
    $('.hidden').actual('innerHeight');
    
    //get hidden element actual outerHeight
    $('.hidden').actual('outerHeight');
    
    // get hidden element actual outerHeight and set the `includeMargin` argument
    $('.hidden').actual('outerHeight',{includeMargin:true});
    
    //if the page jumps or blinks, pass a attribute '{ absolute : true }'
    //be very careful, you might get a wrong result depends on how you makrup your html and css
    $('.hidden').actual('height',{absolute:true});
    
    // if you use css3pie with a float element
    // for example a rounded corner navigation menu you can also try to pass a attribute '{ clone : true }'
    // please see demo/css3pie in action
    $('.hidden').actual('width',{clone:true});

    插件地址:http://dreamerslab.com/works

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-24 05:03 , Processed in 0.059430 second(s), 28 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表