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 继承详解 第一篇
Aug 30 Javascript
javascript 寻找错误方法整理
Jun 15 Javascript
jQuery过滤选择器详解
Jan 13 Javascript
JavaScript小技巧整理篇(非常全)
Jan 26 Javascript
BootStrap Datetimepicker 汉化的实现代码
Feb 10 Javascript
Vue.use源码分析
Apr 22 Javascript
利用node.js实现反向代理的方法详解
Jul 24 Javascript
vue打包的时候自动将px转成rem的操作方法
Jun 20 Javascript
浅析Vue 和微信小程序的区别、比较
Aug 03 Javascript
详解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on
Oct 12 Javascript
LayUi数据表格自定义赋值方式
Oct 26 Javascript
详解JavaScript修改注册表的方法
Jan 05 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
一个可查询所有表的“通用”查询分页类
2006/10/09 PHP
PHP的反射类ReflectionClass、ReflectionMethod使用实例
2014/08/05 PHP
php 实现301重定向跳转实例代码
2016/07/18 PHP
web性能优化之javascript性能调优
2012/12/28 Javascript
jQuery UI 实现email输入提示实例
2013/08/15 Javascript
javascript实时显示北京时间的方法
2015/03/12 Javascript
浅谈javascript属性onresize
2015/04/20 Javascript
关于安卓手机微信浏览器中使用XMLHttpRequest 2上传图片显示字节数为0的解决办法
2016/05/17 Javascript
详细分析Javascript中创建对象的四种方式
2016/08/17 Javascript
微信小程序实现点击返回顶层的方法
2017/07/12 Javascript
jQuery访问浏览器本地存储cookie、localStorage和sessionStorage的基本用法
2017/10/20 jQuery
angular4 JavaScript内存溢出问题
2018/03/06 Javascript
我要点爆”微信小程序云开发之项目建立与我的页面功能实现
2019/05/26 Javascript
ES6 Promise对象的含义和基本用法分析
2019/06/14 Javascript
bootstrap table列和表头对不齐的解决方法
2019/07/19 Javascript
vue通过接口直接下载java生成好的Excel表格案例
2020/10/26 Javascript
[01:28:56]2014 DOTA2华西杯精英邀请赛 5 24 CIS VS DK
2014/05/26 DOTA
[00:55]深扒TI7聊天轮盘语音出处3
2017/05/11 DOTA
Python编程入门的一些基本知识
2015/05/13 Python
Go语言基于Socket编写服务器端与客户端通信的实例
2016/02/19 Python
Python对数据库操作
2016/03/28 Python
Python-嵌套列表list的全面解析
2016/06/08 Python
Python面向对象之类和对象属性的增删改查操作示例
2018/12/14 Python
Python imread、newaxis用法详解
2019/11/04 Python
python实现身份证实名认证的方法实例
2019/11/08 Python
Python:合并两个numpy矩阵的实现
2019/12/02 Python
python中count函数简单用法
2020/01/05 Python
利用keras使用神经网络预测销量操作
2020/07/07 Python
使用tkinter实现三子棋游戏
2021/02/25 Python
期中考试后的反思
2014/02/08 职场文书
真诚的求职信
2014/07/04 职场文书
继承权公证书范本
2015/01/23 职场文书
校车安全管理责任书
2015/05/11 职场文书
身份证丢失证明
2015/06/19 职场文书
感恩教师节主题班会
2015/08/12 职场文书
MySQL数据迁移相关总结
2021/04/29 MySQL