swiper 源码笔记: Util中 extend的写法

2024-09-04 19:32

本文主要是介绍swiper 源码笔记: Util中 extend的写法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

const Util = {
//判断是否是Object 类型isObject(o) {//typeof 等于object的也可能是null, 所以要加上 o !== null ; 后面两个条件是防止 new Date()等类型的object, 要判断它的构造函数return typeof o === 'object' && o !== null && o.constructor && o.constructor === Object;},// "...args"是扩展运算符, 把函数传过来的参数全部析构赋值给args, args的个数没有限制,参考[http://es6.ruanyifeng.com/?search=set&x=6&y=9#docs/array]extend(...args) {//获得参数第一个, 第一个是构造环境的thisconst to = Object(args[0]);//循环args(此时是一个数组),从第二个开始for (let i = 1; i < args.length; i += 1) {const nextSource = args[i];//存在则继续if (nextSource !== undefined && nextSource !== null) {//Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组成的数组,//数组中属性名的排列顺序和使用 for...in 循环遍历该对象时返回的顺序一致 。const keysArray = Object.keys(Object(nextSource));for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {//传过来的object中的属性const nextKey = keysArray[nextIndex];//Object.getOwnPropertyDescriptor() 方法返回指定对象上一个自有属性对应的属性描述符。//(自有属性指的是直接赋予该对象的属性,不需要从原型链上进行查找的属性)const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);//desc 存在并且可枚举if (desc !== undefined && desc.enumerable) {//this.xxx 和 nextSource.xxx(参数的属性)都是Objectif (Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {// 迭代extend 函数Utils.extend(to[nextKey], nextSource[nextKey]);}//this.xxx 不是Object else if (!Utils.isObject(to[nextKey]) && Utils.isObject(nextSource[nextKey])) {//把this.xxx置为空对象to[nextKey] = {};// 迭代extend 函数Utils.extend(to[nextKey], nextSource[nextKey]);} else {//  直接继承to[nextKey] = nextSource[nextKey];}}}}}return to;}
export default Util;

使用方法:

 const swiper = this;Utils.extend(swiper, {autoplay: {running: false,paused: false,run: Autoplay.run.bind(swiper),start: Autoplay.start.bind(swiper),stop: Autoplay.stop.bind(swiper),pause: Autoplay.pause.bind(swiper),onTransitionEnd(e) { if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return;if (e.target !== this) return;swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.autoplay.onTransitionEnd);swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.autoplay.onTransitionEnd);swiper.autoplay.paused = false;if (!swiper.autoplay.running) {swiper.autoplay.stop();} else {swiper.autoplay.run();}},},});

extend进行到autoplay, 是一个对象, 则循环判断autoplay里面的属性, 发现running等状态等不是一个Object, 则直接继续继承;

这篇关于swiper 源码笔记: Util中 extend的写法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136826

相关文章

java 恺撒加密/解密实现原理(附带源码)

《java恺撒加密/解密实现原理(附带源码)》本文介绍Java实现恺撒加密与解密,通过固定位移量对字母进行循环替换,保留大小写及非字母字符,由于其实现简单、易于理解,恺撒加密常被用作学习加密算法的入... 目录Java 恺撒加密/解密实现1. 项目背景与介绍2. 相关知识2.1 恺撒加密算法原理2.2 Ja

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

mybatis的mapper对应的xml写法及配置详解

《mybatis的mapper对应的xml写法及配置详解》这篇文章给大家介绍mybatis的mapper对应的xml写法及配置详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录前置mapper 对应 XML 基础配置mapper 对应 xml 复杂配置Mapper 中的相

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析