经典JS

 

用apply把document当作this传入getId函数,帮助“修正”this;

document.getElementById = (function (func) {return function () {return func.apply(document, arguments);}
})(document.getElementById);//调用
var getId = document.getElementById;
var div = getId('div2');

 

类型判断

var Type = {};for (var i = 0, type; type = ['String', 'Array', 'Number'][i++];) {(function (type) {Type['is' + type] = function (obj) {return Object.prototype.toString.call(obj) === '[object ' + type + ']';}})(type);};

 

自定义事件(一):

var Event = {_listeners: {},    // 添加addEvent: function(type, fn) {if (typeof this._listeners[type] === "undefined") {this._listeners[type] = [];}if (typeof fn === "function") {this._listeners[type].push(fn);}    return this;},// 触发fireEvent: function(type) {var arrayEvent = this._listeners[type];if (arrayEvent instanceof Array) {for (var i=0, length=arrayEvent.length; i<length; i+=1) {if (typeof arrayEvent[i] === "function") {arrayEvent[i]({ type: type });    }}}    return this;},// 删除removeEvent: function(type, fn) {var arrayEvent = this._listeners[type];if (typeof type === "string" && arrayEvent instanceof Array) {if (typeof fn === "function") {// 清除当前type类型事件下对应fn方法for (var i=0, length=arrayEvent.length; i<length; i+=1){if (arrayEvent[i] === fn){this._listeners[type].splice(i, 1);break;}}} else {// 如果仅仅参数type, 或参数fn邪魔外道,则所有type类型事件清除delete this._listeners[type];}}return this;}
};

 

自定义事件(二):

//自定义事件var Event=(function () { var global=this,Event,_default='default';Event=function () { var _listen,_trigger,_remove,_slice=Array.prototype.slice,_shift=Array.prototype.shift,_unshift=Array.prototype.unshift,namespaceCache={},_create,find,each=function (ary,fn) { var ret;for (var i = 0, l=ary.length; i < l; i++){var n=ary[i];ret=fn.call(n,i,n);}return ret;};//添加监听事件,并缓存_listen = function (key,fn,cache) { if(!cache[key]){cache[key]=[];}cache[key].push(fn);};//移除监听_remove=function (key,cache,fn) { if(cache[key]){ //如果存在该监听事件if(fn){ //如果存在回调函数for (var i = cache[key].length; i >=0; i--){if(cache[key][i]===fn){cache[key].splice(i,1); //移除此回调函数
                             }}}else{cache[key]=[]; //清除此事件(为什么存在回调函数时不执行此步骤,奇怪)
                      }}};//触发事件_trigger=function () { var cache = _shift.call(arguments), //第一个参数是cachekey = _shift.call(arguments),  //第二个参数是keyargs = arguments,_self = this,ret,stack= cache[key];if(!stack || !stack.length){ //没有回调函数则直接返回return;}return each(stack, function () { //执行所有的回调函数return this.apply(_self,args);});};//创建事件的实例_create=function (namespace) { var namespace = namespace || _default;var cache ={},offlineStack=[], //离线事件ret={listen:function (key,fn,last) { _listen(key,fn,cache);if(offlineStack===null){return;}if(last==='last'){offlineStack.length && offlineStack.pop()(); //如果是最后一个离线事件,触发此离线事件并移除此事件}else{each(offlineStack,function(){ //如果是多个离线事件,并遍历触发this();});}offlineStack = null; 清空离线事件},//执行一次监听事件one:function (key,fn,last) { _remove(key,cache); //此缓存中移除此事件this.listen(key,fn,last); //添加此事件
                              },remove:function (key,fn) { _remove(key,cache,fn);},trigger:function () { var fn,args,_self=this;_unshift.call(arguments,cache); //将cache缓存添加到arguments参数集合中args=arguments;fn=function(){return _trigger.apply(_self,args);};if(offlineStack){return offlineStack.push(fn);}return fn(); //触发事件
                                }};return namespace ?(namespaceCache[namespace] ? namespaceCache[namespace]:namespaceCache[namespace]= ret ) 
                                    :ret;};return {create: _create,one: function (key, fn, last) {var event = this.create();event.one(key, fn, last);},remove: function (key, fn) {var event = this.create();event.remove(key, fn);},listen: function (key, fn, last) {var event = this.create();event.listen(key, fn, last);},trigger: function () {var event = this.create();event.trigger.apply(this,arguments);}};}();return Event;})();

 

方法绑定:

Function.prototype.bind = function () {var self = this,context  = [].shift.call(arguments),args     = [].slice.call(arguments);return function () {return self.apply( context, [].concat.call(args, [].slice.call(arguments)) )} 
}

 

AOP:

Function.prototype.before = function(beforefn) {var _self = this;return function() {beforefn.apply(this, arguments);return _self.apply(this, arguments);}
}Function.prototype.after = function(afterfn) {var _self = this;return function() {var ret = _self.apply(this, arguments);afterfn.apply(this, arguments);return ret;}
}

 

转载于:https://www.cnblogs.com/jasonoiu/p/Classic-JS.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/470207.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

组件的v-model Mixin extends

一、组件的v-model 前面我们在input中可以使用v-model来完成双向绑定&#xff1a; 这个时候往往会非常方便&#xff0c;因为v-model默认帮助我们完成了两件事&#xff1b;v-bind:value的数据绑定 和 input的事件监听&#xff1b; 如果我们现在封装了一个组件&#xff0c;其…

springmvcget中文乱码_解决SpringMVC Controller 接收页面传递的中文参数出现乱码的问题...

新配置一个spring的MVC项目&#xff0c;发现对Get请求的中文参数出现了乱码&#xff1a;查看了SpingMVC中关于编码的配置(在web.xml中)&#xff0c;如下&#xff1a;encodingFilterorg.springframework.web.filter.CharacterEncodingFilterencodingutf-8forceEncodingtrueencod…

SQL学习之SELECT子句顺序

下面来总计下之前的随笔中所说过的所有的SELECT子句的顺序。 子句            说明            是否必须使用 SELECT 要返回的列或者表达式 是 FROM 从中检索数据的表 …

Vue3过渡动画实现

一、认识动画 在开发中&#xff0c;我们想要给一个组件的显示和消失添加某种过渡动画&#xff0c;可以很好的增加用户体验&#xff1a; React框架本身并没有提供任何动画相关的API&#xff0c;所以在React中使用过渡动画我们需要使用一个第三方库react-transition-group&…

linux退出 putty_使用putty远程连接linux防止关闭putty程序就停止

如题&#xff1a;有时候我们使用putty连接linux的时候执行某个命令运行程序的时候&#xff0c;关闭putty就会出现应用程序也关闭的情况&#xff1b;这里建议就使用如下命令nohup youcommand &(&可加可不加)这个时候默认会在你当前目录创建一个nohup中创建一个nohup.out…

在Linux下不使用密码远程登陆其他Linux

有时需要再一台Linux上登陆其他Linux服务器&#xff0c;通常可以直接使用SSH命令&#xff0c;加入两台服务器一台服务器A&#xff0c;IP地址192.168.1.2&#xff0c;另一 台服务器B&#xff0c;IP地址192.168.1.3&#xff0c;如果想从A服务器使用root用户登陆B服务器只需要在A服…

Vue3 Composition API(一)——setup、reactive、ref、readonly

一、Options API的弊端 在Vue2中&#xff0c;我们编写组件的方式是Options API&#xff1a; Options API的一大特点就是在对应的属性中编写对应的功能模块&#xff1b;比如data定义数据、methods中定义方法、computed中定义计算属性、watch中监听属性改变&#xff0c;也包括生…

pandas 读表格_pandas电子表格的读取(pandas中的read_excel)

上面那篇文章中&#xff0c;初步介绍了一个文本文件的读取&#xff1b;接下来介绍另外一种常见的本地数据格式&#xff0c;那就是Excel电子表格&#xff0c;如果读者在学习或者工作中需要使用Python分析某个Excel表格数据&#xff0c;改如何完成第一个的数据读取呢&#xff1f;…

dex文件格式二

一. dex文件头(1) magic value在DexFile.c dexFileParse函数中 会先检查magic opt啥是magic opt呢? 我们刚刚从cache目录拷贝出来的那个前面的dey 036就是magic opt在源码中会先解析magic opt,然后重设dexfile指针重设magic opt指针后开始解析magic value这 8 个 字节一般是…

Vue3 Composition API(二)——computed、watchEffect、setup中使用ref

一、computed 在前面我们讲解过计算属性computed&#xff1a;当我们的某些属性是依赖其他状态时&#xff0c;我们可以使用计算属性来处理 在前面的Options API中&#xff0c;我们是使用computed选项来完成的&#xff1b;在Composition API中&#xff0c;我们可以在 setup 函数中…

【Git】笔记1

学习廖雪峰Git教程的笔记 Git是什么&#xff1a; Git是目前世界上最先进的分布式版本控制系统 Git与Github的关系&#xff1a;github是一个用git做版本控制的项目托管平台&#xff0c;它为开源项目免费提供Git存储 Git的创建者&#xff1a;Linus&#xff0c;就是创建了linux的那…

支持字典_手把手教你学Python之字典

字典是一种无序可变的容器&#xff0c;字典中的元素都是"键(key):值(value)"对&#xff0c; “键”和“值”之间用冒号隔开&#xff0c;所有“键值对”放在一对大括号“{}”中&#xff0c;元素之间用逗号分隔。在同一个字典中&#xff0c;“键”必须是唯一的&#xf…

Vue3 Composition API(三)——生命周期钩子、Provide函数 和 Inject函数、封装Hook案例、setup顶层编写方式

一、生命周期钩子 我们前面说过 setup 可以用来替代 data 、 methods 、 computed 、watch 等等这些选项&#xff0c;也可以替代 生命周期钩子。 那么setup中如何使用生命周期函数呢&#xff1f; 可以使用直接导入的 onX 函数注册生命周期钩子&#xff1b; 二、Provide函数 和…

单尺度二维离散小波重构(逆变换)idwt2

clc,clear all,close all; load woman; %单尺度二维离散小波分解。分解小波函数haar [cA,cH,cV,cD]dwt2(X,haar); %单尺度二维离散小波重构(逆变换) Yidwt2(cA,cH,cV,cD,haar); figure; subplot(1,2,1),imshow(X,map),title(原始图像); subplot(1,2,2),imshow(Y,map),title(重构…

python导出数据顿号做分隔符_Python语言和matplotlib库做数据可视化分析

这是我的第51篇原创文章&#xff0c;关于数据可视化分析。阅读完本文&#xff0c;你可以知道&#xff1a;1 Python语言的可视化库—matplotlib?2 使用matplotlib实现常用的可视化&#xff1f;0前言数据记者和信息设计师&#xff0c;David McCandless&#xff0c;在他的TED演讲…

Vue3 高级语法(一)—— h函数、jsx

一、认识h函数 Vue推荐在绝大数情况下使用模板来创建你的HTML&#xff0c;然后一些特殊的场景&#xff0c;你真的需要JavaScript的完全编程的能力&#xff0c;这个时候你可以使用渲染函数 &#xff0c;它比模板更接近编译器&#xff1b; 前面我们讲解过VNode和VDOM的改变&#…

android学习笔记30——AndroidMainfest.xml

Manifest.xml文件的职责:指定APP的包名.声明四大组件, 以及启动方式.指定APP运行的进程名称.指定APP权限.指定最小API版本.指定需要连接的库. Manifest.xml的格式:<?xml version"1.0" encoding"utf-8"?> <manifest> <uses-permission /…

华三交换机ping大包命令_华三交换机常用命令

1、查看全部端口的配置display current-configurationdisplay current-configuration interfacedis cu int2、查看指定端口的配置display current-configuration interface 或interface 进入端口配置模式display this 查看当前端口生效配置其中int-type和int-number为端口…

Vue3 高级语法(二)—— 自定义指令、Teleport、Vue插件

一、认识自定义指令 在Vue的模板语法中我们学习过各种各样的指令&#xff1a;v-show、v-for、v-model等等&#xff0c;除了使用这些指令之外&#xff0c;Vue也允许我们来自定义自己的指令。 注意&#xff1a;在Vue中&#xff0c;代码的复用和抽象主要还是通过组件&#xff1b;通…

自己封装的一个原生JS拖动方法。

代码&#xff1a; 1 function drag(t,p){2 3 var point p || null,4 target t || null,5 resultX 0,6 resultY 0;7 8 (!point)? point target : ; //如果没有拖动点&#xff0c;则拖动点默认为整个别拖动元素9 10 function getPos(…