【JavaScript框架封装】实现一个类似于JQuery的基础框架、事件框架、CSS框架、属性框架、内容框架、动画框架整体架构的搭建

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81055973 ...
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/81055973

 

/*
* @Author: 我爱科技论坛
* @Time: 20180715
* @Desc: 实现一个类似于JQuery功能的框架
* V 1.0: 实现了基础框架、事件框架、CSS框架、属性框架、内容框架、动画框架的搭建
* V 2.0:实现了框架的进一步优化,具有良好的扩展性, 可以支持链式访问
* */

 

/ 主框架: 只做一件事,就是用于获取所有的元素集合
(function (w) {
    // 定义一个Xframe对象,后面就是他的构造函数
    var xframe = function (selector, context) {
        // 为了使得后面的函数this始终指向的是xframe框架,这里需要修改函数内部this的指向
        return this.init.apply(this, [selector, context]);
    };

    // 定义一个初始化函数,用于初始化获取所有的元素集合
    // 只要用户使用了类似于JQuery中的选择元素的方法,就开始选择一个元素集合
    // 这里的核心功能:实际上是为了使用一个伪数组实现一个类似于JQuery中的链式访问的功能
    xframe.prototype.init = function (selector, context) {
        // 开始构建一个伪数组:{1 : list[0], 2 : list[1], , , , length : list.length}
        this.length = 0;
        if (typeof  selector === 'string'){
            var nodeList = (context || document).querySelectorAll(selector);
            this.length = nodeList.length;
            for (var i = 0, len = this.length; i < len; i++){
                this[i] = nodeList[i];
            }
        } else if (selector.nodeType){
            // 如果获取的是一个元素节点,文本节点,或者属性节点的话
            this[0] = selector;
            this.length++;
        }

        // 为了可以支持链式访问必须把这个this对象返回出去
        return this;
    };


    // 使用双对象法则继续暴露出去一个对象,进行对象的二次封装
    // 【双对象法则的使用】
    var $$ = function (selctor, context) {
        // 这里使用一个简单的异步加载机制,等待所有的DOM元素执行完毕之后再开始继续向下执行
        if (typeof selctor === 'function'){
            // selector就是DOM元素加载完毕之后的继续向下执行的回调函数
            w.onload = selctor;
        } else {
            // 如果不是一个函数的话
            return new xframe(selecor, context);
        }
    }

    // 添加一个extend方法, 用于扩充一个对象的方法, 扩展向一个类中拷贝方法
    $$.extend = function () {
        // 这里需要分为两种情况:
        // 1. 如果传过来的是一个参数的话,就相当于是给xframe对象添加方法
        // 2. 如果是两个参数的话,就相当于是给一个类扩充方法
        var len = arguments.length,
            target = null,              // target 用来存储需要把方法拷贝进去的目标函数
            i = 1,                      // 初始化变量i, 表示需要开始遍历的起始位置标记
            key;                        // 为了防止定义太多的局部变量,可以把后面需要用到的所有局部变量事先在前面定义好
        if (len === 0){
            return;
        } else if (len === 1){
            // 给xrame对象添加方法
            target = xframe.prototype;
            i--;
        } else{
            // 两个参数的话,那么第一个参数就是我需要拷贝新的方法进去的目标对象
            // 如果是两个参数的话:就不需要修改变量i的值了, 直接从第一个位置开始,拿到第一个参数后, 把第二个参数的方法全部拷贝给第一个对象
            // 注意: 这里有可能也是三个参数或者是多个参数, 因此也可以吧后面的好几个对象的属性或者方法添加给第一个对象
            target = arguments[0];
        }


        // 确定好了target 这个目标对象以后,开始遍历原始对象那个source,把source里面的方法全部都拷贝到这个target对象里面
        for (; i < len; i++){
            // 这里实际上在遍历一个json对象,json对象的每一项实际上就是一个属性或者方法
            for (key in source){
                target[key] = arguments[i][key];
            }
        }
        return target;
    }


    // 为了把主框架里面的局部变量暴露出去供其他模块使用
    w.xframe = w.$ = $$;

})(window);



// 公共框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    /*公共部分*/
    xframe.extend(xframe, {

    });
    /*字符串处理模块*/
    xframe.extend(xframe, {

    });
    /*数组相关*/
    xframe.extend(xframe, {

    });
    /*Math*/
    xframe.extend(xframe, {

    });
    /*数据类型检验*/
    xframe.extend(xframe, {

    });
})(xframe);



// 事件框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    xframe.extend(xframe, {

    });
})(xframe);


// 属性框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    xframe.extend(xframe, {

    });
})(xframe);



// 内容框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    xframe.extend(xframe, {

    });
})(xframe);


// DOM框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    xframe.extend(xframe, {

    });
})(xframe);



// 缓存框架
(function (xframe) {
    // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法)
    xframe.extend({
        each : function () {

        }
    });

    // 不需要参与链式访问的
    xframe.extend(xframe, {

    });
})(xframe);




















// 基础框架: 基本上都是不需要参与链式访问的
// 实现功能: 如果是一个参数的话,就直接给类添加方法
// 如果是多个参数的话,就表示给指定的对象添加方法
xframe.extend(xframe, {
    ltrim: function () {

    },
    rtrim: function () {

    },
    trim: function () {

    },
    ajax: function () {

    },
    formateString: function () {

    },
    random: function () {

    },
    isNumber: function () {

    },
    isBoolean: function () {

    },
    isString: function () {

    },
    isUndefined: function () {

    },
    isObject: function () {

    },
    isNull: function () {

    },
    isArray: function () {

    },

})


// 选择框架
/***
 * 如果下面的框架需要用到上面的框架,就直接可以把上面的去全局变量/对象暴露出去,这里是使用了前面的xframe全局变量
 */
(function ($$) {
    $$.$all = function () {

    };
    $$.$id = function (id) {

    };
    $$.$tag = function () {

    };
    $$.$class = function () {

    };
    $$.$group = function () {

    };
    $$.cengci = function () {

    };
    $$.$select = function () {

    }

})(xframe);


// 事件框架
(function ($$) {
    $$.on = function () {

    }
})(xframe);


// CSS框架
(function ($$) {
    $$.css = function () {

    };

    // 元素的显示与隐藏
    $$.show = function () {

    };
    $$.hide = function () {

    };

    // 元素的宽度和高度
    $$.width = function () {

    };
    $$.height = function () {

    };


    // 元素的滚动宽度和高度
    $$.scrollWidth = function () {

    };
    $$.scrollHeight = function () {

    };

    // 滚动条相对于上面和左边的距离
    $$.scrollTop = function () {

    };
    $$.scrollLeft = function () {

    };


    // 屏幕的宽度和高度
    $$.screenWidth = function () {

    };
    $$.screenHeight = function () {

    };


    // 文档区域的宽度和高度
    $$.wWidth = function () {

    };
    $$.wHeight = function () {

    };


    // 获取文档滚动窗口的相关属性参数信息
    $$.wScrollHeight = function () {

    };
    $$.wScrollWidth = function () {

    };

    // 获取文档滚动窗口距离上面和左边的距离和宽度
    $$.wScrollTop = function () {

    };
    $$.wScrollLeft = function () {

    };
})(xframe);


// 属性框架
(function ($$) {
    // 私有方法
    function removeName() {

    };

    function addName() {

    }

    // 公有方法
    $$.attr = function () {

    };
    $$.addClass = function () {

    };
    $$.removeClass = function () {

    }
})(xframe);


// 内容框架
(function () {
    $$.html = function () {

    };
    $$.text = function () {

    };
    $$.val = function () {

    }
})();


// 动画框架
(function () {
    function Animate() {

    }

    Animate.prototype = {}
})();

 

 

 

 

相关文章
|
4月前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端框架
【10月更文挑战第34天】在数字化时代,后端开发如同一座桥梁,连接着用户界面与数据处理的两端。本文将通过Node.js这一轻量级、高效的平台,带领读者领略后端框架的魅力。我们将从基础概念出发,逐步深入到实战应用,最后探讨如何通过代码示例来巩固学习成果,使读者能够在理论与实践之间架起自己的桥梁。
|
2月前
|
JavaScript 前端开发 测试技术
盘点原生JavaScript中直接触发事件的方式
本文全面探讨了原生JavaScript中触发事件的多种方式,包括`dispatchEvent`、`Event`构造函数、`CustomEvent`构造器、直接调用事件处理器以及过时的`createEvent`和`initEvent`方法。通过技术案例分析,如模拟点击事件、派发自定义数据加载事件和实现提示框系统,帮助开发者掌握这些方法在实际开发中的应用,提升灵活性与兼容性。
52 3
|
3月前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
849 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
4月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
4月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
111 5
|
4月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
82 2
|
4月前
|
缓存 负载均衡 JavaScript
构建高效后端服务:Node.js与Express框架实践
在数字化时代的浪潮中,后端服务的重要性不言而喻。本文将通过深入浅出的方式介绍如何利用Node.js及其强大的Express框架来搭建一个高效的后端服务。我们将从零开始,逐步深入,不仅涉及基础的代码编写,更会探讨如何优化性能和处理高并发场景。无论你是后端新手还是希望提高现有技能的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
4月前
|
JavaScript 前端开发 开发者
JavaScript框架React vs. Vue:一场性能与易用性的较量
JavaScript框架React vs. Vue:一场性能与易用性的较量
88 0
|
4月前
|
Web App开发 JavaScript 前端开发
构建高效后端服务:Node.js与Express框架的实践
【10月更文挑战第33天】在数字化时代的浪潮中,后端服务的效率和可靠性成为企业竞争的关键。本文将深入探讨如何利用Node.js和Express框架构建高效且易于维护的后端服务。通过实践案例和代码示例,我们将揭示这一组合如何简化开发流程、优化性能,并提升用户体验。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用技巧。
|
JavaScript 前端开发 HTML5
《HTML5+JavaScript动画基础》——2.6 小结
本章介绍了理解书中示例所需要的JavaScript基础知识。现在你应该了解了如何创建HTML5文件、调试、循环、事件以及事件处理程序。本章简单介绍了JavaScript对象,基本的用户交互,并且创建了一系列用于简化代码的工具函数。
1388 0

热门文章

最新文章