JS动态调用方法名示例介绍


Posted in Javascript onDecember 18, 2013

先看看JS的一个函数

JavaScript eval() 函数
定义和用法

eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。
语法

eval(string)

参数 描述

string 必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。

返回值

通过计算 string 得到的值(如果有的话)。

说明

该方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。因此请不要为 eval() 函数传递 String 对象来作为参数。

如果试图覆盖 eval 属性或把 eval() 方法赋予另一个属性,并通过该属性调用它,则 ECMAScript 实现允许抛出一个 EvalError 异常。

抛出

如果参数中没有合法的表达式和语句,则抛出 SyntaxError 异常。

如果非法调用 eval(),则抛出 EvalError 异常。

如果传递给 eval() 的 Javascript 代码生成了一个异常,eval() 将把该异常传递给调用者。

提示和注释

提示:虽然 eval() 的功能非常强大,但在实际使用中用到它的情况并不多。

实例

例子 1

在本例中,我们将在几个字符串上运用 eval(),并看看返回的结果:

<script type="text/javascript"> eval("x=10;y=20;document.write(x*y)") 
document.write(eval("2+2")) 
var x=10 
document.write(eval(x+17)) 
</script>

输出:

200
4
27

例子 2

看一下在其他情况中,eval() 返回的结果:

eval("2+3") // 返回 5 
var myeval = eval; // 可能会抛出 EvalError 异常 
myeval("2+3"); // 可能会抛出 EvalError 异常

可以使用下面这段代码来检测 eval() 的参数是否合法:
try { 
alert("Result:" + eval(prompt("Enter an expression:",""))); 
} catch(exception) { 
alert(exception); 
}

第一种方法就是使用js里面的eval

下面是自己写的例子

call("showmsg"); function call(functionName){ 
eval("this."+functionName+"()"); 
} 
function showmsg(){ 
alert("success"); 
}

eval能将你拼接的字符串自动识别为方法,并调用。

但弊端也是很大的,想象一下,某个人改你调用地方的方法名,便能调用你的任意方法。

第二种方法主要用作自己定义的方法

主要是第二种方法需要特定的方式去写

function call(functionName) { 
showmsgs["showmsg"](); 
} var showmsgs = { showmsg: function () { 
alert("success"); 
} 
} 
call("showmsg");
Javascript 相关文章推荐
Javascript 遍历对象中的子对象
Jul 03 Javascript
Aptana调试javascript图解教程
Nov 30 Javascript
JavaScript中常用的六种互动方法示例
Mar 13 Javascript
使用AngularJS和PHP的Laravel实现单页评论的方法
Jun 19 Javascript
在react-router4中进行代码拆分的方法(基于webpack)
Mar 08 Javascript
Node.js模拟发起http请求从异步转同步的5种用法
Sep 26 Javascript
用webpack4开发小程序的实现方法
Jun 04 Javascript
js Array.slice的8种不同用法示例
Jul 10 Javascript
layui添加动态菜单与选项卡
Jul 26 Javascript
在Node.js中将SVG图像转换为PNG,JPEG,TIFF,WEBP和HEIF格式的方法
Aug 22 Javascript
JS使用H5实现图片预览功能
Sep 30 Javascript
vue 数据遍历筛选 过滤 排序的应用操作
Nov 17 Javascript
javascript页面动态显示时间变化示例代码
Dec 18 #Javascript
页面实时更新时间的JS实例代码
Dec 18 #Javascript
带左右箭头图片轮播的JS代码
Dec 18 #Javascript
用js代码改变单选框选中状态的简单实例
Dec 18 #Javascript
浅析document.ready和window.onload的区别讲解
Dec 18 #Javascript
浅谈Javascript 执行顺序
Dec 18 #Javascript
Javascript浅谈之引用类型
Dec 18 #Javascript
You might like
两个强悍的php 图像处理类1
2009/06/15 PHP
php 将bmp图片转为jpg等其他任意格式的图片
2009/06/29 PHP
PHP微框架Dispatch简介
2014/06/12 PHP
php简单定时执行任务的实现方法
2015/02/23 PHP
php将字符串随机分割成不同长度数组的方法
2015/06/01 PHP
IE7提供XMLHttpRequest对象为兼容
2007/03/08 Javascript
获得所有表单值的JQuery实现代码[IE暂不支持]
2012/05/24 Javascript
jQuery插件jQuery-JSONP开发ajax调用使用注意事项
2013/11/22 Javascript
如何设置一定时间内只能发送一次请求
2014/02/28 Javascript
jQuery实用技巧必备(中)
2015/11/03 Javascript
简单的JS时钟实例讲解
2016/01/13 Javascript
Javascript设计模式之观察者模式(推荐)
2016/03/29 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
Ext JS动态加载JavaScript创建窗体的方法
2016/06/23 Javascript
angular.JS实现网页禁用调试、复制和剪切
2017/03/31 Javascript
JavaScript实现时间表动态效果
2017/07/15 Javascript
javascript如何用递归写一个简单的树形结构示例
2017/09/06 Javascript
vuex的module模块用法示例
2018/11/12 Javascript
利用Python-iGraph如何绘制贴吧/微博的好友关系图详解
2017/11/02 Python
Python对多属性的重复数据去重实例
2018/04/18 Python
基于python代码实现简易滤除数字的方法
2018/07/17 Python
Python正则表达式指南 推荐
2018/10/09 Python
python3 读取Excel表格中的数据
2018/10/16 Python
pytorch 预训练层的使用方法
2019/08/20 Python
python解析yaml文件过程详解
2019/08/30 Python
Python hashlib模块加密过程解析
2019/11/05 Python
python根据文本生成词云图代码实例
2019/11/15 Python
python实现人机五子棋
2020/03/25 Python
Python实现哲学家就餐问题实例代码
2020/11/09 Python
加拿大在线眼镜零售商:SmartBuyGlasses加拿大
2019/05/25 全球购物
数据员岗位职责
2013/11/19 职场文书
餐饮采购员岗位职责
2014/03/15 职场文书
新农村建设典型材料
2014/05/31 职场文书
食堂管理制度范本
2015/08/04 职场文书
导游词幽默开场白
2019/06/26 职场文书
Python+Tkinter制作专属图形化界面
2022/04/01 Python