-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathCSSClass.js
More file actions
113 lines (113 loc) · 2.96 KB
/
CSSClass.js
File metadata and controls
113 lines (113 loc) · 2.96 KB
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
(function () {
// add indexOf to Array prototype for IE<8
// this isn't failsafe, but it works on our behalf
Array.prototype.CSSClassIndexOf = Array.prototype.indexOf || function (item) {
var length = this.length;
for (var i = 0; i<length; i++)
if (this[i]===item) return i;
return -1;
};
// check if classList interface is available (@see https://developer.mozilla.org/en-US/docs/Web/API/element.classList)
var cl = ("classList" in document.createElement("a"));
// actual Element prototype manipulation
var p = Element.prototype;
if(cl) {
if(!p.hasClass)
p.hasClass = function(c) {
var e = Array.prototype.slice.call(this.classList);
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(!this.classList.contains(c[i]))
return false;
return true;
};
if(!p.addClass)
p.addClass = function(c) {
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(!this.hasClass(c[i]))
this.classList.add(c[i]);
return this;
};
if(!p.removeClass)
p.removeClass = function(c) {
var e = this.className.split(' ');
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(this.hasClass(c[i]))
this.classList.remove(c[i]);
return this;
};
if(!p.toggleClass)
p.toggleClass = function(c) {
c = c.split(' ');
for(var i=0; i<c.length; i++)
this.classList.toggle(c[i]);
return this;
};
} else {
if(!p.hasClass)
p.hasClass = function(c) {
var e = this.className.split(' ');
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(e.CSSClassIndexOf(c[i])===-1)
return false;
return true;
};
if(!p.addClass)
p.addClass = function(c) {
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(!this.hasClass(c[i]))
this.className = this.className!==''?(this.className+' '+c[i]):c[i];
return this;
};
if(!p.removeClass)
p.removeClass = function(c) {
var e = this.className.split(' ');
c = c.split(' ');
for(var i=0; i<c.length; i++)
if(this.hasClass(c[i]))
e.splice(e.CSSClassIndexOf(c[i]), 1);
this.className = e.join(' ');
return this;
};
if(!p.toggleClass)
p.toggleClass = function(c) {
c = c.split(' ');
for(var i=0; i<c.length; i++)
if (this.hasClass(c[i]))
this.removeClass(c[i]);
else
this.addClass(c[i]);
return this;
};
}
var pl = NodeList.prototype;
if (!pl.hasClass)
pl.hasClass = function (c, all) {
if (all===undefined) all = true;
for (var i=this.length-1; i>=0; --i) {
var hc = this[i].hasClass(c);
if (all && !hc) return false;
if (!all && hc) return true;
}
return true;
};
if (!pl.addClass)
pl.addClass = function (c) {
for (var i=0; i<this.length; ++i)
this[i].addClass(c);
};
if (!pl.removeClass)
pl.removeClass = function (c) {
for (var i=0; i<this.length; ++i)
this[i].removeClass(c);
};
if (!pl.toggleClass)
pl.toggleClass = function (c) {
for (var i=0; i<this.length; ++i)
this[i].toggleClass(c);
};
})();