首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS 实现放大缩小拖拽采坑之旅

    本文首发于政采云前端团队博客:纯 JS 实现放大缩小拖拽采坑之旅 https://www.zoo.team/article/scaling ?...前言 最近团队需要做一个智能客服悬浮窗功能,需要支持拖动、放大缩小等功能,因为这个是全局插件,为了兼容性考虑全部使用原生 JS 实现,不引用任何第三方库或者插件。...三个坑点 拖拽采宝时会导致采宝放大缩小 采宝显示在屏幕边界时被遮挡显示不全 采宝放大和缩小后,位置发生变化 (一)拖拽时会导致采宝放大缩小 我们在操作采宝时,不管是鼠标拖动还是点击放大缩小,我们的事件都需要绑定在采宝头部的图标上...这样就会出现在拖动采宝的时候,采宝会放大和缩小。 ?...'放大缩小' (三)采宝放大和缩小后,位置发生变化 通过上图,我们可以看到,当小采宝处在显示屏边界时,点击放大后再点击缩小,我们发现采宝的位置发生了变化。

    5.8K10

    JS 外观模式

    简介 外观模式(Facade)为子系统中的一组接口提供了一个一致的界面,此模块定义了一个高层接口,这个接口值得这一子系统更加容易使用。 外观模式JS中常常用于解决浏览器兼容性问题。 2....实现 外观模式不仅简化类中的接口,而且对接口与调用者也进行了解耦。外观模式经常被认为开发者必备,它可以将一些复杂操作封装起来,并创建一个简单的接口用于调用。...---- 本文是系列文章,可以相互参考印证,共同进步~ JS 抽象工厂模式 JS 工厂模式 JS 建造者模式 JS 原型模式 JS 单例模式 JS 回调模式 JS 外观模式 JS 适配器模式 JS 利用高阶函数实现函数缓存...(备忘模式) JS 状态模式 JS 桥接模式 JS 观察者模式 网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~ 参考: 设计模式之外观模式 《Javascript...设计模式》 - 张荣铭

    1.3K40

    JS 状态模式

    简介 状态模式(State)允许一个对象在其内部状态改变的时候改变它的行为,对象看起来似乎修改了它的类。...简而言之,当遇到很多同级if-else或者switch的时候,可以使用状态模式来进行简化。...---- 本文是系列文章,可以相互参考印证,共同进步~ JS 抽象工厂模式 JS 工厂模式 JS 建造者模式 JS 原型模式 JS 单例模式 JS 回调模式 JS 外观模式 JS 适配器模式 JS 利用高阶函数实现函数缓存...(备忘模式) JS 状态模式 JS 桥接模式 JS 观察者模式 网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~ 参考: 《Javascript 设计模式...》 - 张荣铭 设计模式之状态模式

    2.4K40

    JS设计模式之代理模式

    https://blog.csdn.net/j_bleach/article/details/71374535 什么是代理模式 代理模式,类似于明星的经纪人,想要拜访明星...而在JS当中,如果想访问一个类,需要通过另一个类来间接访问 。不同于装饰器,那种动态加载一个对象,可以说在代理模式当中,代理是早已既定的。 别人眼中的代理 ?...现在,当我们引入代理模式之后,代码可能是这样的: 代理: class getDelivery { constructor() { } gets(a) {...而后者在代码上还多了一些,但为什么这里还是推荐使用后面这种模式来写代码呢? 使用代理模式的好处 首先介绍一个面向对象设计原则,单一职责原则。 又称单一功能原则,面向对象五个基本原则(SOLID)之一。...代理模式,在实践当中还可以应用于缓存ajax异步数据,惰性加载等等方面,本文不做详细讲解,仅作抛砖引玉的入门参考。

    77041

    设计模式之命令模式-JS

    这些记录着订餐信息的清单,便是命令模式中的命令对象。 命令模式的用途 命令模式是最简单和优雅的模式之一,命令模式中的命令(command)指的是一个执行某些特定事情的指令。   ...设计模式的主题总是把不变的事物和变化的事物分离开来,命令模式也不例外。按下按钮之后会发生一些事情是不变的,而具体会发生什么事情是可变的。...命令模式的由来,其实是回调(callback)函数的一个面向对象的替代品   在面向对象设计中,命令模式的接收者被当成command对象的属性保存起来,同时约定执行命令的操作调用command.execute...用闭包实现的命令模式如下代码所示:   <!...宏命令是命令模式与组合模式的联用产物。

    1.1K20

    JS模式 之通用模式(译)

    条件 使用if和else的模式以及反模式 获取全局对象 不直接用widows当做全局对象 直接用windows的风险在于,JS代码不只能在浏览器环境能执行。...单var模式 用一个var定义多个变量 例如 var a = 1 , b = 2 , sum = a + b , myobject = {} , i , j; 定义提升 函数内变量不管是在哪定义的...,其实js在解析时,都会把变量定义放到函数的开始 为了避免变量重名,建议把在函数的变量的定义在函数的开始。...(译者注:对于有JIT的JS引擎,这个这条可以忽略) 用i+=1代替i++ for-in循环 for-in循环优化 用for-in遍历对象属性时,用hasOwnProperty对非原型属性进行过滤...== "function") { Object.prototype.myMethod = function () { // implementation... }; } switch模式 增加switch

    91030

    JS设计模式之工厂模式

    msg: 'msg2', link: 'https://baidu.com' }) // Sharing msg2 from https://baidu.com via WeChat 其实JS...中大可不必这样做,直接传构造函数为参数就可以,因为JS中函数是一等公民。...这里列出代码只是用于学习这个模式。 抽象工厂模式 提供一个接口以创建一系列相关或相互依赖的对象,而无需指定它们具体的类。...许多文章喜欢以不同的操作系统匹配不同的外观举例,但是我们既然都用上了跑在浏览器里的JS,那就尽可能不考虑跨平台的问题。 所以我想到了移动端和桌面端UI不同,这或许是一个应用抽象工厂模式的良好切入点。...什么时候不要使用 由于JS的动态类型,运用工厂方法可能会导致复杂的类型问题。如果你没有提供一个统一的接口,推荐直接使用new创建对象(TypeScript完美解决)。

    99520

    LSM-Tree 的写放大放大、读放大、空间放大RockDB 写放大简单分析参考文档

    放大、读放大、空间放大 基于 LSM-Tree 的存储系统越来越常见了,如 RocksDB、LevelDB。...RocksDB 和 LevelDB 通过后台的 compaction 来减少读放大(减少 SST 文件数量)和空间放大(清理过期数据),但也因此带来了写放大(Write Amplification)的问题...在 HDD 作为主流存储的时代,RocksDB 的 compaction 带来的写放大问题并没有非常明显。这是因为: HDD 顺序读写性能远远优于随机读写性能,足以抵消写放大带来的开销。...所以,顺序写相比随机写带来的好处,能不能抵消写放大带来的开销,这是个问题。 SSD 的使用寿命和其写入量有关,写放大太严重会大大缩短 SSD 的使用寿命。...所以,在 SSD 上,LSM-Tree 的写放大是一个非常值得关注的问题。而写放大、读放大、空间放大,三者就像 CAP 定理一样,需要做好权衡和取舍。

    17.7K51

    JS 原型模式

    如果你希望自己去实现原型模式,而不直接使用Object.create 。...总结 原型模式在JavaScript里的使用简直是无处不在,其它很多模式有很多也是基于prototype的,这里大家要注意的依然是浅拷贝和深拷贝的问题,免得出现引用问题。...---- 本文是系列文章,可以相互参考印证,共同进步~ JS 抽象工厂模式 JS 工厂模式 JS 建造者模式 JS 原型模式 JS 单例模式 JS 回调模式 JS 外观模式 JS 适配器模式 JS 利用高阶函数实现函数缓存...(备忘模式) JS 状态模式 JS 桥接模式 JS 观察者模式 网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~ 参考: 设计模式之原型模式 《Javascript...设计模式》 - 张荣铭

    1.4K10
    领券