mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
102 lines
2.4 KiB
JavaScript
102 lines
2.4 KiB
JavaScript
import Vue from 'vue';
|
|
const isServer = Vue.prototype.$isServer;
|
|
|
|
const trim = function(string) {
|
|
return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
|
|
};
|
|
|
|
export function hasClass(el, cls) {
|
|
if (!el || !cls) return false;
|
|
if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
|
|
if (el.classList) {
|
|
return el.classList.contains(cls);
|
|
} else {
|
|
return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
|
|
}
|
|
};
|
|
|
|
export function addClass(el, cls) {
|
|
if (!el) return;
|
|
var curClass = el.className;
|
|
var classes = (cls || '').split(' ');
|
|
|
|
for (var i = 0, j = classes.length; i < j; i++) {
|
|
var clsName = classes[i];
|
|
if (!clsName) continue;
|
|
|
|
if (el.classList) {
|
|
el.classList.add(clsName);
|
|
} else {
|
|
if (!hasClass(el, clsName)) {
|
|
curClass += ' ' + clsName;
|
|
}
|
|
}
|
|
}
|
|
if (!el.classList) {
|
|
el.className = curClass;
|
|
}
|
|
};
|
|
|
|
export function removeClass(el, cls) {
|
|
if (!el || !cls) return;
|
|
var classes = cls.split(' ');
|
|
var curClass = ' ' + el.className + ' ';
|
|
|
|
for (var i = 0, j = classes.length; i < j; i++) {
|
|
var clsName = classes[i];
|
|
if (!clsName) continue;
|
|
|
|
if (el.classList) {
|
|
el.classList.remove(clsName);
|
|
} else {
|
|
if (hasClass(el, clsName)) {
|
|
curClass = curClass.replace(' ' + clsName + ' ', ' ');
|
|
}
|
|
}
|
|
}
|
|
if (!el.classList) {
|
|
el.className = trim(curClass);
|
|
}
|
|
};
|
|
export const once = function(el, event, fn) {
|
|
var listener = function() {
|
|
if (fn) {
|
|
fn.apply(this, arguments);
|
|
}
|
|
off(el, event, listener);
|
|
};
|
|
on(el, event, listener);
|
|
};
|
|
|
|
export const on = (function() {
|
|
if (!isServer && document.addEventListener) {
|
|
return function(element, event, handler) {
|
|
if (element && event && handler) {
|
|
element.addEventListener(event, handler, false);
|
|
}
|
|
};
|
|
} else {
|
|
return function(element, event, handler) {
|
|
if (element && event && handler) {
|
|
element.attachEvent('on' + event, handler);
|
|
}
|
|
};
|
|
}
|
|
})();
|
|
|
|
export const off = (function() {
|
|
if (!isServer && document.removeEventListener) {
|
|
return function(element, event, handler) {
|
|
if (element && event) {
|
|
element.removeEventListener(event, handler, false);
|
|
}
|
|
};
|
|
} else {
|
|
return function(element, event, handler) {
|
|
if (element && event) {
|
|
element.detachEvent('on' + event, handler);
|
|
}
|
|
};
|
|
}
|
|
})();
|