-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathjquery.actual.js
80 lines (69 loc) · 2.26 KB
/
jquery.actual.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*! Copyright 2011, Ben Lin (http://dreamerslab.com/)
* Licensed under the MIT License (LICENSE.txt).
*
* Version: 1.0.2
*
* Requires: jQuery 1.2.3+
*/
$.fn.extend({
actual : function( method, options ){
var $hidden, $target, configs, css, tmp, actual, fix, restore;
// check if the jQuery method exist
// maybe we can skip this and let jQuery to show the debug msg
if( !this[ method ]) throw '$.actual => The jQuery method "' + method + '" you called does not exist';
configs = $.extend({
absolute : false,
clone : false
}, options );
$target = this;
fix = configs.clone === true ?
function(){
// this is useful with css3pie
$target = $target.filter( ':first' ).clone().css({
position : 'absolute',
top : -1000
}).appendTo( 'body' );
} :
function(){
// get all hidden parents
$hidden = $target.parents().andSelf().filter( ':hidden' );
css = configs.absolute === true ?
{ position : 'absolute', visibility: 'hidden', display: 'block' } :
{ visibility: 'hidden', display: 'block' };
tmp = [];
// save the origin style props
// set the hidden el css to be got the actual value later
$hidden.each( function(){
var _tmp = {}, name;
for( name in css ){
// save current style
_tmp[ name ] = this.style[ name ];
// set current style to proper css style
this.style[ name ] = css[ name ];
}
tmp.push( _tmp );
});
};
restore = configs.clone === true ?
function(){
// remove DOM element after getting the width
$target.remove();
} :
function(){
// restore origin style values
$hidden.each( function( i ){
var _tmp = tmp[ i ], name;
for( name in css ){
this.style[ name ] = _tmp[ name ];
}
});
};
fix();
// get the actual value with user specific methed
// it can be 'width', 'height', 'outerWidth', 'innerWidth'... etc
actual = $target[ method ]();
restore();
// IMPORTANT, this plugin only return the value of the first element
return actual;
}
});