【趣味JavaScript】利用className原生自定义封装实现快速操作html元素中的class属性,功能包含添加、删除、替换、验证是否存在, 极简方式轻量级!【附代码】

简介: 利用className原生自定义封装实现快速操作html元素中的class属性
+关注继续查看

🚀 个人主页 极客小俊
✍🏻 作者简介:web开发者、设计师、技术分享博主
🐋 希望大家多多支持一下, 我们一起进步!😄
🏅 如果文章对你有帮助的话,欢迎评论 💬点赞👍🏻 收藏 📂加关注

2.png

我们可以使用className属性来实现对class类的设置,或者封装一些小函数

自定义一个hasClass函数

为了添加的class类不重复,所以我们在添加class类之前也应该判断一下当前元素是否已经存在了要添加的class类名称,所以这里我们可以封装一个hasClass()函数来实现这个查询是否存在的功能

代码如下

/**
 * @param obj        object
 * @param ClassName  string
 * @return {boolean}
 */
function hasClass(obj, ClassName) {
   
    if (obj.className === obj.id) {
   
        console.log('class名称和ID名称同名了,建议修改');
        return;
    }
    var reg = new RegExp("\\b" + obj.className + "\\b");
    return reg.test(obj.className);
}

自定义一个addClass函数

我们可以封装一个addClass()函数来为元素添加css中的class类

/**
 * @param obj        object
 * @param ClassName  string
 */
function addClass(obj, ClassName) {
   
    if (!hasClass(obj, ClassName)) {
   
        obj.className = ClassName;
    }
}

自定义一个removeClass函数

我们也可以封装一个removeClass()方法来删除指定的class类

代码如下

/**
 * @param obj
 * @param ClassName
 */
function removeClass(obj, ClassName) {
   
    if (hasClass(obj, ClassName)) {
   
        obj.attributes.removeNamedItem('class');
    }
}

自定义一个toggleClass函数

我们可以基于 addClass()方法hasClass()方法removeClass()方法 这三个方法创建一个toggleClass()的方法 用于切换一个元素class名 这样非常方便!

巴拉巴拉巴拉....😝😝😝

/**
 * @param obj        object
 * @param ClassName  string
 */
function toggleClass(obj, ClassName) {
   
    if (hasClass(obj, ClassName)) {
   
        removeClass(obj, ClassName);
    } else {
   
        addClass(obj, ClassName);
    }
}

把这些函数全部放到一个单独的js文件当中,使用时,引入一下就可以了!
3.gif

举个梨子
4.gif

相关文章
|
5天前
|
存储 前端开发 JavaScript
基于前端技术原生HTML、JS、CSS 电子病历编辑器源码
基于前端技术原生HTML、JS、CSS 电子病历编辑器源码
17 0
|
5天前
|
JavaScript 前端开发
原生JavaScript之dom与setInterval/settimeout结合实现动画
原生JavaScript之dom与setInterval/settimeout结合实现动画
17 1
|
5天前
|
JavaScript 前端开发
原生JavaScript之dom表单改变和鼠标常用事件
那么好,本次我们聊聊表单改变时如何利用onchange方法来触发input改变事件以及鼠标常用的滑入滑出,点击down和点击up事件.
15 2
|
5天前
|
JavaScript 前端开发
原生JavaScript之dom如何进行事件监听(事件捕获/冒泡)
原生JavaScript之dom如何进行事件监听(事件捕获/冒泡)
13 1
|
5天前
|
JavaScript 前端开发
原生JavaScript之dom添加表单验证
原生JavaScript之dom添加表单验证
13 2
原生JavaScript之dom添加表单验证
|
5天前
|
JavaScript 前端开发 索引
原生JavaScript之函数特殊对象arguments
原生JavaScript之函数特殊对象arguments
20 0
|
5天前
|
JavaScript
原生js插入HTML元素
原生js插入HTML元素
10 1
|
5天前
|
JavaScript
jQuery学习(四)— jQuery的ready事件和原生JS的load事件的区别
jQuery学习(四)— jQuery的ready事件和原生JS的load事件的区别
|
24天前
|
JavaScript
原生js实现文件下载并设置请求头header
原生js实现文件下载并设置请求头header
|
24天前
|
JavaScript 前端开发
原生js实现ajax请求带请求头header
原生js实现ajax请求带请求头header
热门文章
最新文章
相关产品
云迁移中心
相关实验场景
更多
推荐文章
更多