首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

基于发布-订阅的原生 JS 插件封装

用原生 JS 封装一个动画插件。效果如下: ? 这个飞驰的小球看起来是不是特有灵性呢?没错,它就是用原生JS实现的。 接下来,就让我们深入细节,体会其中的奥秘。...一、需求分析 封装一个插件,将小球的 DOM 对象作为参数传入,使得小球在鼠标按下和放开后能够运动,在水平方向做匀减速直线运动,初速度为鼠标移开瞬间的速度,在竖直方向的运动类似于自由落体运动。...四、采用发布-订阅 估计读完这段代码,你也体会到了这个功能的实现是非常容易实现的。但是实际上,作为一个插件的标准来讲,这段代码是存在一些潜在的问题的,这些问题并不是逻辑上的问题,而是设计问题。...(手动滑稽) 五、优化代码 //Drag.jsif (typeof Subscribe === 'undefined') { throw new ReferenceError('没有引入subscribe.js...在这里我并不是简单讲讲效果的实现、贴贴代码就过去了,而是带你体验了封装插件的整个过程。有了发布-订阅的场景,理解这个设计思想就更加容易了。

3.1K20

原生JS封装Ajax插件(同域&&jsonp跨域)

前言 抛出一个问题,其实所谓的熟悉原生JS,怎样的程度才是熟悉呢? 用原生Js封装了一个Ajax插件,引入一般的项目,传传数据,感觉挺可行的。。。...主要原理是利用了script 标签可以跨域请求的特点,由其 src 属性发送请求到服务器,服务器返回 JS 代码,网页端接受响应,然后就直接执行了,这和通过 script 标签引用外部文件的原理是一样的...属性只在第一次设置的时候起作用,导致 script 标签没法重用,所以每次完成操作之后要移除; JSONP这种请求方式中,参数依旧需要编码; 如果不设置超时,就无法得知此次请求是成功还是失败; 由于代码有点长...,就放个计时器的代码吧,完整代码见AjaxPlugin //超时处理 if(params.time){ scriptTag.timer=setTimeout(function(){...params.fail&¶ms.fail({message:"over time"}); window[cbName]=null; },params.time); } 插件详细解析及使用方法见

3K21
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用vue封装右键菜单插件

    在package.json中,CLI默认是把vue和core-js放在dependencies下的,我们开发的插件是要给其他开发者引用的,如果我们打包的产物中包含Vue包的话可能会引发各种问题,比如用户可能会在引入我们的包之后会在...那么,我们就可以在package.json的script标签里添加build命令用以执行插件的打包,代码如下。...,在引用插件时就会报错声明文件不存在,因此我们需要额外做下述操作: 在tsconfig.jsonz中添加下述代码,打包时在项目的指定位置自动生成配置文件。...我们可以通过手动将其设置为false,让其在打包时使用内联样式,这样就能解决样式失效的问题了,我们在vue.config.js中加入下述代码。...在插件全局声明一个变量menuVM,默认声明为null 指令内部触发右键事件时,调用我们封装的函数,用menuVM去接收其返回值 此时我们创建一个全局点击事件的监听,如果menuVM不为null,我们就把这个元素移除

    2.7K30
    领券