javascript函数值的重写

原文:javascript函数值的重写

javascript函数值的重写

定义了一个函数,需要重写这个函数并使用原先的函数值。做法是:

1.定义一个变量让原先函数的值指向它,把原先函数的指向一个新的函数值,在这个函数值中执行原先的函数值。

    function foo(){
        console.log("foo");
    }

    var fooTemp = foo;
    foo = function(){
        console.log("begin");
        fooTemp();
        console.log("finish");
    };

    foo();// begin foo finish
    fooTemp = null;
    foo();// begin Uncaught TypeError: fooTemp is not a function

2.这样的做法可能不安全,定义的临时函数可能会在后面的内容中被修改,所以把它放在一个立刻执行的函数中执行。

    function foo(){
        console.log("foo");
    }

    (function(){
        var fooTemp = foo;
        foo = function(){
            console.log("begin");
            fooTemp();
            console.log("finish");
        };
    })();

    foo(); // begin foo finish

3.函数parseInt在之传入一个参数的情况下,如果传入的字符串首位是0且次位不是x,若IE8就会用八进制解析,所以要重写parseInt。

    alert(parseInt("09"));//IE8:0, Chrome:9

    (function(){
        var parseIntTemp = parseInt;
        parseInt = function(str){
            return parseIntTemp(str, 10);
        };
    })();

    alert(parseInt("09")); // IE8:9, Chrome:9

雨木阳子
2015年10月13日
Javascript_FunctionValue_Override

时间: 2024-12-25 14:34:05

javascript函数值的重写的相关文章

JavaScript函数劫持

一.为什么我会写这篇文章 这篇文章其实是在一个偶然的机会下发现了居然有JavaScript劫持这种东西,虽然这种东西在平时用的比较少,而且一般实用价值不高,但是在一些特殊的情况下还是要使用到的,所以在这里我就简单的介绍一下 不知道你们在平时有没有注意到这样的一种情况就是每当使用alert()方法的时候,都会感觉这样的方法太过的单调,像加个样式或者是什么的.下面我们就来讲解一下 二.一个关于JavaScript函数劫持的小DEMO 下面我们就来演示一下对alert方法进行劫持的小案例,样式不是很漂

JavaScript学习总结(四)——this、原型链、javascript面向对象

一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化,当然也可以使用call.apply修改this指向的对象.它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用 1.0.猜猜答案 代码如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8&quo

07-19

由于之前实现简单的登录和注册系统,使用的框架都较为简单,在后续开发过程中,很多功能不便于实现于是做了新的调研,暂停了Spring框架的研究. 首先,为了实现页面的动态效果,我们将表单的提交方式更改为jQuery中的ajax方式,以实现一些网页异步更新的操作. 以用户注册页面为例使用ajax实现页面的异步更新. 使用jQuery需包含一个jquery.js 实现方式: 在jsp中 在后端AcTion中 但只用text传递消息有很多不便的地方,比如页面需要从数据库读取或注入表单,这时要用到json数

55种开源数据可视化工具简介

55种开源数据可视化工具简介 雪姬 2015-04-21 11:47:56 数据可视化 评论(2)   数据时代数据可视化成为理解和表达数据的有效甚至是唯一的手段. 一共56个,盘点最实用的大数据可视化分析工具 工欲善其事必先利其器,本文对55个流行的数据可视化工具开源协议,主页,文档,案例等资源的进行简单介绍,其中包括著名的D3.js,R,Gephi,Raphaël,Processing.js,Tableau Public,Google Chart Tools,Arbor.js等,资料来源ht

司徒正美文章列表

由于本人对司徒正美文章的喜欢,特此整理文章列表如下. 一个带完整的RBAC授权系统的rails应用(第一部分)(司徒正美, 3年前, 12/6549) 一个带完整的RBAC授权系统的rails应用(第二部分)(司徒正美, 3年前, 1/1135) 随机生成十六进制颜色(司徒正美, 3年前, 0/340) ruby中的类变量与实例变量(司徒正美, 3年前, 0/231) ruby模拟多个构造器(司徒正美, 3年前, 0/153) ruby的实例方法(写方法,读方法与读写方法)(司徒正美, 3年前,

编写高质量JS代码上

想写出高效的javascript类库却无从下手: 尝试阅读别人的类库,却理解得似懂给懂: 打算好好钻研js高级函数,但权威书上的内容太零散, 即使记住“用法”,但到要“用”的时候却没有想“法”. 也许你和我一样,好像有一顾无形的力量约束着我们的计划,让我们一再认为知识面的局限性,致使我们原地踏步,难以向前跨越. 这段时间,各种作业.课程设计.实验报告,压力倍增.难得挤出一点点时间,绝不睡懒觉,整理总结往日所看的书,只为了可以离写自己的类库近一点. 本文参考自<javascript语言精粹>和&

【55种开源数据可视化工具简介】

大数据时代数据可视化成为理解和表达数据的有效甚至是唯一的手段. 工欲善其事必先利其器,本文对55个流行的数据可视化工具开源协议,主页,文档,案例等资源的进行简单介绍,其中包括著名的D3.js,R,Gephi,Rapha?l,Processing.js,Tableau Public,Google Chart Tools,Arbor.js等,资料来源http://selection.datavisualization.ch/ 下面安照字母顺序进行介绍(已更新至第11个,未完待续--) 1 Arbor

无废话ExtJs 入门教程十五[员工信息表Demo:AddUser]

无废话ExtJs 入门教程十五[员工信息表Demo:AddUser] extjs技术交流,欢迎加群(201926085) 前面我们共介绍过10种表单组件,这些组件是我们在开发过程中最经常用到的,所以一定要用到非常熟练才可以,今天我们会通过一个员工信息表实例,再把这些组件串一下. (1)TextField  (2)Botton  (3)NumberField (4)Hidden (5)DataFiedl (6)RadioGroup (7)CheckBoxGroup (8)Combobox (9)F

【工具】开源可视化工具

http://www.36dsj.com/archives/28060 流程图  graphiz   自动化布局 拓扑图  d3  sigma.js Cola.js是一个开源的JavaScript库,使用基于约束的优化技术的排列HTML5文档和图表.它和D3.js 和svg.js配合使用会更好.核心布局是基于C ++的libcola库的JavaScript代码完全重写.它有为d3.js设计的适配器,允许您将cola作为D3力布局的一个简易替换.它不像D3力的布局收敛到一个局部最优,而是通过一个简